IOS开发中延迟执行和取消的示例分析-创新互联

这篇文章主要为大家展示了“IOS开发中延迟执行和取消的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“IOS开发中延迟执行和取消的示例分析”这篇文章吧。

成都一家集口碑和实力的网站建设服务商,拥有专业的企业建站团队和靠谱的建站技术,10多年企业及个人网站建设经验 ,为成都数千家客户提供网页设计制作,网站开发,企业网站制作建设等服务,包括成都营销型网站建设,品牌网站建设,同时也为不同行业的客户提供网站制作、成都做网站的服务,包括成都电商型网站制作建设,装修行业网站制作建设,传统机械行业网站建设,传统农业行业网站制作建设。在成都做网站,选网站制作建设服务商就选成都创新互联

在 Objective-C 中延迟执行还是很常见的需求,通常有如下几种方式可供选择:

performSelector:

想要延迟调用某个方法:

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

取消延迟的方法:

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

这里需要注意参数需要保持一致,否则取消失败。

NSTimer

想要延迟调用某个方法:

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 中并没有提供取消执行的相关 API。我们只能自己实现这个取消的逻辑:

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;
}
使用的话可以这样:

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

如果想要延迟,可以先声明成成员变量并赋值:

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

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

self.task(YES);

这种写法的核心思想是根据传入的 Bool 值,来控制 dispatch_after 回调 block 中的方法是否需要执行。看起来是取消了,但实际上还是被 GCD 放到 RunLoop 里去占用主线程资源了。

dispatch_source

我们还可以利用 dispatch_source 中的定时器,来实现延时/取消操作:

@property (strong, nonatomic) dispatch_source_t timer;
// 队列
dispatch_queue_t queue = dispatch_get_main_queue();
// 创建 dispatch_source
dispatch_source_t timer = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0, queue);
// 声明成员变量
self.timer = timer;
// 设置两秒后触发
dispatch_time_t startTime = dispatch_time(DISPATCH_TIME_NOW, 3.0 * NSEC_PER_SEC);
// 设置下次触发事件为 DISPATCH_TIME_FOREVER
dispatch_time_t nextTime = DISPATCH_TIME_FOREVER;
// 设置精确度
dispatch_time_t leeway = 0.1 * NSEC_PER_SEC;
// 配置时间
dispatch_source_set_timer(timer, startTime, nextTime, leeway);
// 回调
dispatch_source_set_event_handler(timer, ^{
  // ...
});
// 激活
dispatch_resume(timer);

需要取消的话:

dispatch_source_cancel(self.timer);

以上是“IOS开发中延迟执行和取消的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联网站建设公司行业资讯频道!

另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前名称:IOS开发中延迟执行和取消的示例分析-创新互联
地址分享:http://csdahua.cn/article/gojis.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流