IOS開(kāi)發(fā)中延遲執(zhí)行和取消的示例分析

這篇文章主要為大家展示了“IOS開(kāi)發(fā)中延遲執(zhí)行和取消的示例分析”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“IOS開(kāi)發(fā)中延遲執(zhí)行和取消的示例分析”這篇文章吧。

讓客戶(hù)滿(mǎn)意是我們工作的目標(biāo),不斷超越客戶(hù)的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶(hù),將通過(guò)不懈努力成為客戶(hù)在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名注冊(cè)、虛擬空間、營(yíng)銷(xiāo)軟件、網(wǎng)站建設(shè)、濱州網(wǎng)站維護(hù)、網(wǎng)站推廣。

在 Objective-C 中延遲執(zhí)行還是很常見(jiàn)的需求,通常有如下幾種方式可供選擇:

performSelector:

想要延遲調(diào)用某個(gè)方法:

[self performSelector:@selector(delay) withObject:nil afterDelay:3.0];

取消延遲的方法:

[NSObject cancelPreviousPerformRequestsWithTarget:self selector:@selector(delay) object:nil];

這里需要注意參數(shù)需要保持一致,否則取消失敗。

NSTimer

想要延遲調(diào)用某個(gè)方法:

self.timer = [NSTimer scheduledTimerWithTimeInterval:2.0 target:self selector:@selector(delay) userInfo:nil repeats:NO];

取消延遲的方法:

[self.timer invalidate];
GCD

dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
    // ...
});

dispatch_after 是比較常用的方法,但是 Objective-C 中并沒(méi)有提供取消執(zhí)行的相關(guān) API。我們只能自己實(shí)現(xiàn)這個(gè)取消的邏輯:

typedef void (^Task)(BOOL cancel);
Task delay(NSTimeInterval time,void (^task)()) {
  __block void (^closure)() = task;
  __block Task result;
  Task delayedClosure = ^(BOOL cancel){
    if (closure) {
      void (^internalClosure)() = closure;
      if (!cancel) {
        dispatch_async(dispatch_get_main_queue(), internalClosure);
      }
    }
    closure = nil;
    result = nil;
  };
  
  result = delayedClosure;
  
  dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(time * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
    if (delayedClosure) {
      delayedClosure(NO);
    }
  });
  return result;
}
使用的話(huà)可以這樣:

delay(60, ^{
  // ...
});

如果想要延遲,可以先聲明成成員變量并賦值:

@property (copy, nonatomic) Task task;
self.task = delay(60, ^{
  // ...
});

最后在需要的地方取消就行:

self.task(YES);

這種寫(xiě)法的核心思想是根據(jù)傳入的 Bool 值,來(lái)控制 dispatch_after 回調(diào) block 中的方法是否需要執(zhí)行??雌饋?lái)是取消了,但實(shí)際上還是被 GCD 放到 RunLoop 里去占用主線(xiàn)程資源了。

dispatch_source

我們還可以利用 dispatch_source 中的定時(shí)器,來(lái)實(shí)現(xiàn)延時(shí)/取消操作:

@property (strong, nonatomic) dispatch_source_t timer;
// 隊(duì)列
dispatch_queue_t queue = dispatch_get_main_queue();
// 創(chuàng)建 dispatch_source
dispatch_source_t timer = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0, queue);
// 聲明成員變量
self.timer = timer;
// 設(shè)置兩秒后觸發(fā)
dispatch_time_t startTime = dispatch_time(DISPATCH_TIME_NOW, 3.0 * NSEC_PER_SEC);
// 設(shè)置下次觸發(fā)事件為 DISPATCH_TIME_FOREVER
dispatch_time_t nextTime = DISPATCH_TIME_FOREVER;
// 設(shè)置精確度
dispatch_time_t leeway = 0.1 * NSEC_PER_SEC;
// 配置時(shí)間
dispatch_source_set_timer(timer, startTime, nextTime, leeway);
// 回調(diào)
dispatch_source_set_event_handler(timer, ^{
  // ...
});
// 激活
dispatch_resume(timer);

需要取消的話(huà):

dispatch_source_cancel(self.timer);

以上是“IOS開(kāi)發(fā)中延遲執(zhí)行和取消的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

標(biāo)題名稱(chēng):IOS開(kāi)發(fā)中延遲執(zhí)行和取消的示例分析
標(biāo)題來(lái)源:http://bm7419.com/article30/igedpo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站、動(dòng)態(tài)網(wǎng)站、網(wǎng)站制作、自適應(yīng)網(wǎng)站、企業(yè)網(wǎng)站制作、App設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)