1.下面代码打印什么?
- (void)test2
{
dispatch_queue_t queue = dispatch_get_global_queue(0, 0);
dispatch_async(queue, ^{
NSLog(@"1");
// 这句代码的本质是往Runloop中添加定时器,注意:已经拿到RunLoop,并添加定时器了,只是没有run,所以下一句代码可不要
[self performSelector:@selector(test) withObject:nil afterDelay:.0];
NSLog(@"3");
// [[NSRunLoop currentRunLoop] addPort:[[NSPort alloc] init] forMode:NSDefaultRunLoopMode];
// [[NSRunLoop currentRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate distantFuture]];
});
}
只会打印“1”和“3”,performSelector:withObject:afterDelay:的本质是往Runloop中添加定时器 ,子线程默认没有启动Runloop
{
NSThread *thread = [[NSThread alloc] initWithBlock:^{
NSLog(@"1");
[[NSRunLoop currentRunLoop] addPort:[[NSPort alloc] init] forMode:NSDefaultRunLoopMode];
[[NSRunLoop currentRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate distantFuture]];
}];
[thread start];
//如果线程不保活,这里线程就已经退出了,就会崩溃
[self performSelector:@selector(test) onThread:thread withObject:nil waitUntilDone:YES];
}
本文深入探讨了Grand Central Dispatch (GCD) 和 RunLoop 的工作机制,解释了为什么 performSelector:withObject:afterDelay: 不会立即执行,以及如何正确地在子线程中启动 RunLoop,确保异步任务的执行。
4667

被折叠的 条评论
为什么被折叠?



