Dispatch_apply (线程同步)
2017-09-04 本文已影响47人
天心鸥兹
在某些特殊的开发场景下,我们可能会有这样的需求:n个任务并发。
![](https://img.haomeiwen.com/i1485773/a667e91a89d891d8.png)
比如我们需要以每个像素为基准来处理计算image。这个时候使用如下代码极有可能引起线程爆炸或死锁
![](https://img.haomeiwen.com/i1485773/cb10f855ebb984c0.png)
使用Dispatch_apply来解决这个需求,会对性能有比较大的提升,让我来看看它的基本用法。
Dispatch_apply类似for循环,它会在指定的queue中执行block任务n次,如果是并发队列,则会并发执行block任务。
dispatch_apply是一个同步调用,block任务执行n次后才返回。
举一个比较好理解的例子,假设我们要从服务器获取一个字典元素的数组,这时考虑使用Dispatch_apply可以快速的实现批量的字典转模型任务
![](https://img.haomeiwen.com/i1485773/4cf0fa6ded1f0c87.png)
简单来说Dispatch_apply是GCD提供的可以将迭代器转换为并发任务的方法,某些特殊场景下使用它可以获得不错的性能提升。