dispatch_sync是同步线程,若当前线程运行在主线程里面,那就是主线程。然后,在主线程执行log。此时,dispatch_sync等待dispatch_get_main_queue执行完毕。然而,dispatch_get_main_queue在等待dispatch_sync释放主线程。2说,等3输出了我才能输出
3说,等2输出了我才能输出,相互等待发生了。
NSLog(@"---1");
dispatch_sync(dispatch_get_main_queue(), ^{
NSLog(@"---2");
});
NSLog(@"---3");
// 解决方法1
NSLog(@"---1");
dispatch_async(dispatch_get_main_queue(), ^{
NSLog(@"---2");
});
NSLog(@"---3");
// 解决方法2
NSLog(@"---1");
dispatch_sync(dispatch_get_global_queue(0, 0), ^{
NSLog(@"---2");
});
NSLog(@"---3");
2和3不会被打印,因为1在异步子线程中执行,所以可能1比4先打印。2需要在主线程中同步执行,当打印了1后,把异步代码放到后台等待获取主线程,先执行4。然而遇到个死循环阻塞了主线程,而2又需要等待主线程才能执行,所以2处于永远等待获取主线程。
dispatch_async(dispatch_get_global_queue(0, 0), ^{
NSLog(@"----1");
dispatch_sync(dispatch_get_main_queue(), ^{
NSLog(@"----2");
});
NSLog(@"---3");
});
NSLog(@"---4");
while (YES) {
}
// 解决方法1
dispatch_async(dispatch_get_global_queue(0, 0), ^{
NSLog(@"----1");
dispatch_sync(dispatch_get_global_queue(0, 0), ^{
NSLog(@"----2");
});
NSLog(@"---3");
});
NSLog(@"---4");
while (YES) {
}
3和4永远不会被打印被锁死
NSLog(@"1");
dispatch_async(dispatch_get_main_queue(), ^{
NSLog(@"2");
dispatch_sync(dispatch_get_main_queue(), ^{
NSLog(@"3");
});
NSLog(@"4");
});
NSLog(@"5");
// 解决方法1
NSLog(@"1");
dispatch_async(dispatch_get_main_queue(), ^{
NSLog(@"2");
dispatch_sync(dispatch_get_global_queue(0, 0), ^{
NSLog(@"3");
});
NSLog(@"4");
});
NSLog(@"5");
// 解决方法2
NSLog(@"1");
dispatch_async(dispatch_get_main_queue(), ^{
NSLog(@"2");
dispatch_async(dispatch_get_main_queue(), ^{
NSLog(@"3");
});
NSLog(@"4");
});
NSLog(@"5");
网友评论