延迟执行代码:
- (void)delayDo : (id)sender {
NSLog(@"do:%@",sender);
}
Sleep(NSThread)方法:卡主当前线程来实现延迟操作。
[NSThread sleepForTimeInterval:3];
GCD方法:
//在主线程延迟执行
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
[self delayDo:@"GCD"];
});
//在子线程延迟执行
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5 * NSEC_PER_SEC)), dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
[self delayDo:@"Global-GCD"]; });
NSTimer方法:这个方法必须要在主线程中使用.可以传递参数.可以取消操作,可以暂停,可以立即执行延迟操作,比较灵活可以掌控。
因为这个方法可以暂停,这里设置了一个变量isRun来判断是否在运行.
1 //计时器对象
2 NSTimer * timer;
3 //作为计时器判断状态的变量
4 BOOL isRun;
开始计时,repeats:NO.只执行一次. YES,循环重复执行.
1 isRun = YES;
2 timer = [NSTimer scheduledTimerWithTimeInterval:1.0f target:self selector:@selector(delayDo:) userInfo:@"abc" repeats:YES];
暂停操作:
复制代码
1 if (isRun) {
2 #warning 此方法是暂停的功能 其实是把时间拉远了
3 isRun = NO;
4 [timer setFireDate:[NSDate distantFuture]];
5 }
6 else if (!isRun) {
7 #warning 恢复计时器
8 isRun = YES;
9 [timer setFireDate:[NSDate date]];
10 }
复制代码
不等待计时器,立即执行延迟操作
1 [timer fire];
销毁/彻底取消计时器
1 #waring 此方法策底取消了Timer 不是暂停
2 [timer invalidate];
这里要说明一下,并不是只有invalidate方法才能销毁计时器,当repeats属性设为NO,计时器运行以后将会自动销毁.
那么参数呢? NSTimer的参数是userInfo,所以要使用userInfo方法才能提取到正确的参数
1 NSlog(@"sender:%@",[sender userInfo]);
performSelector(NSObject)方法
这是iOS中常用的一种延迟执行方法.
特点:这个方法必须要在主线程中使用.可以传递参数.可以取消操作,不能暂停.
1 //不带参数
2 [self performSelector:@selector(delayDo:) withObject:nil afterDelay:1.0f];
3 //带参数
4 [self performSelector:@selector(delayDo:) withObject:@"abc" afterDelay:1.0f];
取消操作分为2种:
(1)取消所有延迟执行操作
[NSObject cancelPreviousPerformRequestsWithTarget:self];
(2)取消指定的延迟执行操作
当你取消指定的延迟操作时,操作的唯一标示是传递的参数,只有传递了正确的参数才能取消操
复制代码
1 //取消不传参的方法
2 [NSObject cancelPreviousPerformRequestsWithTarget:self selector:@selector(delayDo:) object:nil];
3 //取消传参的方法
4 [NSObject cancelPreviousPerformRequestsWithTarget:self selector:@selector(delayDo:) object:@"abc"];
复制代码