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];
}