dispatch_async(dispatch_get_main_queue(), ^{})

1 请问以下代码的输出的顺序是什么?

 - (void)test{
    dispatch_async(dispatch_get_main_queue(), ^{
        NSLog(@"main");
    });
    for (int i = 0; i < 100000; i++) {
        NSLog(@"i");
    }
    [self tesfFunc];
}
- (void)tesfFunc{
    NSLog(@"testFunc");
}

经Xcode10测试:
输出如下:


屏幕快照 2018-10-12 下午1.54.48.png

main 最后输出的。根据结果推导出:
如下这种方式添加的:dispatch_async(dispatch_get_main_queue(), ^{})。block是在最后完成。苹果到底做了什么事情,未知,待续。实际中的影响就是其它代码完成block的代码才会执行。欢迎在评论区讨论!!!

2 避免主线程中 dispatch_async(dispatch_get_main_queue(), ^{})block中的代码延迟执行,SDWebImage做了如下:

#ifndef dispatch_queue_async_safe
#define dispatch_queue_async_safe(queue, block)\
if (dispatch_queue_get_label(DISPATCH_CURRENT_QUEUE_LABEL) == dispatch_queue_get_label(queue)) {\
block();\
} else {\
dispatch_async(queue, block);\
}
#endif

#ifndef dispatch_main_async_safe
#define dispatch_main_async_safe(block) dispatch_queue_async_safe(dispatch_get_main_queue(), block)
#endif

3 如果不是asyn main_queue的不是在代码都执行完其它代码,再执行

- (void)test{
   dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
        NSLog(@"global");
    });
    for (int i = 0; i < 100000; i++) {
        NSLog(@"i");
    }
    [self tesfFunc];
}
- (void)tesfFunc{
    NSLog(@"testFunc");
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容