通过信号量实现异步调用转同步

栏目: IT技术 · 发布时间: 5年前

在 iOS 开发中,我们通常会通过 delegate 或者 block 的方式来实现异步回调。如图 1 所示,在异步方法 doSomethingWithCallback: 中执行一些耗时操作,然后通过执行 callback block 将结果返回给调用者,并执行后续的逻辑。

通过信号量实现异步调用转同步

这是一种很常见的写法,它的好处就是使代码看起来很紧凑,统一在回调 block 中处理异步结果,但缺点就是,如果结果处理逻辑很复杂,就会使 callback block 里的代码很冗长,且如果结果处理过程中又需要调用其他异步方法,很容易出现 block 嵌套的情况。

下面介绍介绍一种通过信号量 semaphore 把异步调用转成同步调用的方式,代码如图 2 中红框所示:我们先创建一样信号量,初始值为 0,然后调用异步方法,接着通过 dispatch_semaphore_wait 实现加锁等待,在回调 block 中保存结果数据,并通过 dispatch_semaphore_signal 实现解锁,最后再统一处理结果,整个流程看起来就相当于一次同步调用了。

通过信号量实现异步调用转同步

虽然使用起来有点麻烦,但是在有些场景下我们确实可能需要把异步逻辑转成同步,希望能帮到你。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法设计与分析

算法设计与分析

郑宗汉//郑晓明 / 清华大学 / 2011-7 / 45.00元

《算法设计与分析(第2版)》系统地介绍算法设计与分析的概念和方法,共4部分内容。第1部分介绍算法设计与分析的基本概念,结合穷举法、排序问题及其他一些算法,对算法的时间复杂性的概念及复杂性的分析方法作了较为详细的叙述;第2部分以算法设计技术为纲,从合并排序、堆排序、离散集合的union和find操作开始,进而介绍递归技术、分治法、贪婪法、动态规划、回溯法、分支与限界法和随机算法等算法设计技术及其复杂......一起来看看 《算法设计与分析》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具