IOS开发中延迟执行和取消开发中延迟执行和取消
主要介绍了IOS开发中延迟执行和取消的相关资料,需要的朋友可以参考下
在 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, ^{
// ...
});
最后在需要的地方取消就行:
评论0
最新资源