博客
关于我
GCD学习之Dispatch Group
阅读量:736 次
发布时间:2019-03-22

本文共 528 字,大约阅读时间需要 1 分钟。

发送组

    在多个处理程序被添加到Dispatch Queue时,如果所有处理程序都完成后需要执行结束处理,常常会遇到这种情况。在使用单个串行Dispatch Queue时,只需将想执行的处理全部添加到该队列中,并在最后添加结束处理即可实现。但是在使用并发Dispatch Queue或同时使用多个Dispatch Queue时,源代码会变得非常复杂。

    为了解决这种情况,可以使用Dispatch Group。在下面的源代码示例中,会额外添加3个Block到Global Dispatch Queue,这些Block在全部执行完毕后,会自动执行Main Dispatch Queue中用于结束处理的Block。

dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0); dispatch_group_t group = dispatch_group_create(); dispatch_group_async(group, queue, ^{ NS dette("blk0"); }); dispatch_group_async(...);

转载地址:http://rlggz.baihongyu.com/

你可能感兴趣的文章
MySQL底层概述—2.InnoDB磁盘结构
查看>>
MySQL底层概述—3.InnoDB线程模型
查看>>
MySQL底层概述—4.InnoDB数据文件
查看>>
MySQL底层概述—5.InnoDB参数优化
查看>>
MySQL底层概述—6.索引原理
查看>>
MySQL底层概述—7.优化原则及慢查询
查看>>
MySQL底层概述—8.JOIN排序索引优化
查看>>
MySQL底层概述—9.ACID与事务
查看>>
Mysql建立中英文全文索引(mysql5.7以上)
查看>>
mysql建立索引的几大原则
查看>>
Mysql建表中的 “FEDERATED 引擎连接失败 - Server Name Doesn‘t Exist“ 解决方法
查看>>
MySQL开源工具推荐,有了它我卸了珍藏多年Nactive!
查看>>
MySQL异步操作在C++中的应用
查看>>
MySQL引擎讲解
查看>>
Mysql当前列的值等于上一行的值累加前一列的值
查看>>
MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>
MySQL必知必会(组合Where子句,Not和In操作符)
查看>>
MySQL必知必会总结笔记
查看>>
MySQL快速入门
查看>>
MySQL快速入门——库的操作
查看>>