美文网首页
GCD线程死锁

GCD线程死锁

作者: 北纬357 | 来源:发表于2019-06-03 14:36 被阅读0次

    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");
    

    相关文章

      网友评论

          本文标题:GCD线程死锁

          本文链接:https://www.haomeiwen.com/subject/wpscxctx.html