GCD温故而知新2

上篇我们留了一个问题就是 同步主队列为啥会崩这里我们来解释一下

256FD59E-40DB-4B05-A825-16042BD6BACA.png

BE883C47-D34C-4942-A583-F9CC4409F3F0.png

首先看这个上面这个图 这个方法是在viewDidLoad里面调用的(主队列调用)
首先代码运行到a同步说明不会开辟新的线程会阻塞当前线程(就是block里面c要在主线程里面执行的)会立马回调就还立马执行c 但是main_queue要求是等主线程的事情做完了在回调执行c 这样就矛盾了 (同步要求我立马在主线程执行c主队列说等主线程执行玩也就是d NSLoge(@"2")执行完这个方法结束在执行c).所以矛盾 我主线程是立马执行c啊还是等主线程执行完了在执行c啊 就崩了.

156D450A-17C3-4255-A3E1-DFB339A9F646.png

异步不会阻塞当前线程不会立马回调(打印NSlog@"2")main_queue要求等主线程事情干完在回调.这样没有矛盾啊 打印完"1" 就会打印"3"就会打印接着就会走下面的for循环当这个方法走完了(主线程没有事情做了)就会打印"2".虽然是异步但是是主队列是不会开辟 新线程的"2"也是在主队列中执行.

69B9A7AF-8ACD-4AAF-9D25-DC3C4E1D699F.png

我们再来进阶一下 我们把同步主队列写在异步中程序就不会蹦.来我们分析一下
1---第一种情况
代码肯定是先运行到a 接着运行b 运行到b异步全局队列 这里会创建一个异步线程接下来 就会走c或者走g因为两个线程嘛谁先走也不一定 先假设走了g 又走了c 接着就会走d这是时候是同步主线程 同步肯定是要阻塞当前线程的(立马回调走e) main_queue肯定是要求主项成的事情都干完了在走e的你会发现 并不矛盾因为g已经走完了啊 所以就会走e呗 e走完在走f呗完事了..
打印的log顺序是 1 5 2 3 4 这只是一种情况
2---第二种情况
程序先运行到a接着是b开辟了一个新线程 可能走g也可能走c 我们假设走了c 先走c接下来走d还是走g呢 其实也是不确定的 我们先确定c走完了g还没走完 接着d又走了.这可是个同步主队啊(同步要求立马在当前线程{不是主线程}执行e main_queue要求慌啥,你这个非主线程先等一下啊 ,等主线程执行完了在主线程中执行e).这样非主线程就被阻塞了 等执行完了g 在执行了e 接着就是f 打印的log顺序就是1 2 5 3 4
上面只有这两种情况.我们接着进阶

B491BA07-50C2-4DEB-AFF5-4B928B5C4923.png

如上图所示 打印的log有五中情况. 重点是3 一定是在5后面的..有兴趣的朋友可以用sleep();函数做延迟亲自试一下.
1 5 2 3 4
1 5 2 4 3

1 2 4 5 3
1 2 5 3 4
1 2 5 4 3

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容