- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event {
[self delay1];
[self delay2];
[self delay3];
}
- (void)delay1 {
// 睡眠3秒 会卡主线程
NSLog(@"%@",[NSThread currentThread]);
[NSThread sleepForTimeInterval:3];
}
- (void)delay2 {
[self performSelector:@selector(download:) withObject:@"abc" afterDelay:3]; // 三秒钟自动调用run方法
}
- (void)delay3 {
NSLog(@"touchBegin");
// 三秒后回到主线程,执行block中的代码
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
/*
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
NSLog(@"-----task----");
});
*/
// 三秒钟开启新线程,执行block中的代码
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), queue, ^{ // 在哪个线程执行,和队列类型有关
NSLog(@"----task %@",[NSThread currentThread]);
});
NSLog(@"touchEnd");
// 打印结果
// 2015-08-10 16:22:12.436 9 GCD延迟执行[5300:132082] touchBegin
// 2015-08-10 16:22:12.437 9 GCD延迟执行[5300:132082] touchEnd
// 2015-08-10 16:22:15.730 9 GCD延迟执行[5300:132082] -----task----
}
- (void)download:(NSString *)url {
NSLog(@"download %@ --- %@",url,[NSThread currentThread]);
}
GCD延迟执行
最新推荐文章于 2023-06-29 16:47:53 发布