http://blog.csdn.net/hello_hwc/article/details/41409135

一、dispatch_group
把一组任务提交到队列中,这些队列可以不相关,然后坚挺这组任务完成的事件。
几个用到的函数
1、dispatch_group_create创建一个调度任务组

  1. func dispatch_group_create() -> dispatch_group_t!

2、dispatch_group_async 把一个任务异步提交到任务组里

  1. func dispatch_group_async(_ group: dispatch_group_t!,
  2. _ queue: dispatch_queue_t!,
  3. _ block: dispatch_block_t!)

参数: group 提交到的任务组,这个任务组的对象会一直持续到任务组执行完毕
        queue 提交到的队列,任务组里不同任务的队列可以不同
        block 提交的任务

3、dispatch_group_enter/dispatch_group_leave

  1. func dispatch_group_enter(_ group: dispatch_group_t!)
  2. func dispatch_group_leave(_ group: dispatch_group_t!)

这两个方法显示的讲任务组中的任务未执行完毕的任务数目加减1,这种方式用在不使用dispatch_group_async来提交任务,注意:这两个函数要配合使用,有enter要有leave,这样才能保证功能完整实现。也可以用这对函数来让一个闭包关联多个Group

4、dispatch_group_notify 用来监听任务组事件的执行完毕

  1. func dispatch_group_notify(_ group: dispatch_group_t!,
  2. _ queue: dispatch_queue_t!,
  3. _ block: dispatch_block_t!)

参数: group监听的任务组
queue 执行完毕的这个闭包所在的队列
block 执行完毕所响应的任务
5、dispatch_group_wait 设置等待时间,在等待时间结束后,如果还没有执行完任务组,则返回。返回0代表执行成功,非0则执行失败

  1. long dispatch_group_wait ( dispatch_group_t group, dispatch_time_t timeout );

二、完整的代码解析,模拟提交三个下载任务

  1. class ViewController: UIViewController{
  2. override func viewDidLoad(){
  3. super.viewDidLoad()
  4. var hwcGroup = dispatch_group_create()//创建group
  5. var globalQueueDefault = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0)//全局队列,这个队列为并行队列
  6. var userCreateQueue =  dispatch_queue_create("com.test.helloHwc",DISPATCH_QUEUE_SERIAL)//创建一个用户队列,这个队列为串行队列
  7. downLoadTask1(group: hwcGroup,queue: globalQueueDefault)
  8. downLoadTask2(group: hwcGroup,queue: userCreateQueue)
  9. downLoadTask3(group: hwcGroup,queue: userCreateQueue)
  10. //letresult = dispatch_group_wait(hwcGroup,DISPATCH_TIME_FOREVER)
  11. dispatch_group_notify(hwcGroup,dispatch_get_main_queue()){
  12. NSLog("Group tasks are done")
  13. }
  14. println("Now viewDidLoad is done")
  15. }
  16. func downLoadTask1(#group:dispatch_group_t,queue:dispatch_queue_t){
  17. dispatch_group_async(group,queue){
  18. sleep(3)
  19. NSLog("Task1 is done")
  20. }
  21. }
  22. func downLoadTask2(#group:dispatch_group_t,queue:dispatch_queue_t){
  23. dispatch_group_async(group,queue){
  24. sleep(3)
  25. NSLog("Task2 is done")
  26. }
  27. }
  28. func downLoadTask3(#group:dispatch_group_t,queue:dispatch_queue_t){
  29. dispatch_group_async(group,queue){
  30. sleep(3)
  31. NSLog("Task3 is done")
  32. }
  33. }
  34. override func didReceiveMemoryWarning(){
  35. super.didReceiveMemoryWarning()
  36. }
  37. }

可以看到输出为

  1. Now viewDidLoad is done
  2. Task2 is done
  3. Task1 is done
  4. Task3 is done
  5. Group task is done

这里task1提交到全局队列中,task2和task3提交到用户穿件的串行队列中,所以task1和task2同时输出,task3在task2结束两秒后输出。

如果把注释那行取消,会等待一段时间,再返回,读者可以自己去试验下

三、关于如何使用dispatch_group_enter/dispatch_group_leave如何使用

  1. <pre name="code" class="plain">class ViewController: UIViewController{
  2. override func viewDidLoad(){
  3. super.viewDidLoad()
  4. var hwcGroup = dispatch_group_create()//创建group
  5. var globalQueueDefault = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0)//全局队列,这个队列为并行队列
  6. for index:UInt32 in 1...3{
  7. dispatch_group_enter(hwcGroup)//提交了一个任务,任务数目加1
  8. manualDownLoad(index){
  9. println("Task\(index) is done")
  10. dispatch_group_leave(hwcGroup)//完成一个任务,任务数目减1
  11. }
  12. }
  13. let result = dispatch_group_wait(hwcGroup,DISPATCH_TIME_FOREVER)//等待直到完成
  14. dispatch_group_notify(hwcGroup,dispatch_get_main_queue()){
  15. println("Group tasks are done")
  16. }
  17. println("Now viewDidLoad is done")
  18. }
  19. func manualDownLoad(num:UInt32,block:()->()){
  20. println("Downloading task\(num)")
  21. sleep(num)
  22. block()
  23. }
  24. override func didReceiveMemoryWarning(){
  25. super.didReceiveMemoryWarning()
  26. }
  27. }

输出

  1. Downloading task1
  2. Task1 is done
  3. Downloading task2
  4. Task2 is done
  5. Downloading task3
  6. Task3 is done
  7. Now viewDidLoad is done
  8. Group is done

可以看到,同步进行了下载,这里的任务是串行的,实际消耗时间9s。当然,也可以把下载的任务提交到异步队列中

  1. class ViewController: UIViewController{
  2. override func viewDidLoad(){
  3. super.viewDidLoad()
  4. var hwcGroup = dispatch_group_create()//创建group
  5. var globalQueueDefault = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0)//全局队列,这个队列为并行队列
  6. for index:UInt32 in 1...3{
  7. dispatch_group_enter(hwcGroup)//提交了一个任务,任务数目加1
  8. manualDownLoad(index,queue:globalQueueDefault){
  9. NSLog("Task\(index) is done")
  10. dispatch_group_leave(hwcGroup)//完成一个任务,任务数目减1
  11. }
  12. }
  13. dispatch_group_notify(hwcGroup,dispatch_get_main_queue()){
  14. NSLog("Group tasks are done")
  15. }
  16. NSLog("Now viewDidLoad is done")
  17. }
  18. func manualDownLoad(num:UInt32,queue:dispatch_queue_t, block:()->()){
  19. dispatch_async(queue){
  20. NSLog("Downloading task\(num)")
  21. sleep(num)
  22. block()
  23. }
  24. }
  25. override func didReceiveMemoryWarning(){
  26. super.didReceiveMemoryWarning()
  27. }
  28. }

这样的话,输出是

  1. Downloading task1
  2. Downloading task2
  3. Downloading task3
  4. Now viewDidLoad is done
  5. Task1 is done
  6. Task2 is done
  7. Task3 is done

由于三个模拟的下载任务是并行的,所以实际消耗时间3s

完整详解GCD系列(三)dispatch_group的更多相关文章

  1. 「视频直播技术详解」系列之七:直播云 SDK 性能测试模型

    ​关于直播的技术文章不少,成体系的不多.我们将用七篇文章,更系统化地介绍当下大热的视频直播各环节的关键技术,帮助视频直播创业者们更全面.深入地了解视频直播技术,更好地技术选型. 本系列文章大纲如下: ...

  2. CocoaPods详解之(三)----制作篇

    CocoaPods详解之----制作篇 作者:wangzz 原文地址:http://blog.csdn.net/wzzvictory/article/details/20067595 转载请注明出处 ...

  3. 第6章 传输层(详解TCP的三次握手与四次挥手)

    第6章 传输层 传输层简介 传输层为网络应用程序提供了一个接口,并且能够对网络传输提供了可选的错误检测.流量控制和验证功能.TCP/IP传输层包含很多有用的协议,能够提供数据在网络传输所需的必要寻址信 ...

  4. 详解TCP的三次握手四次断开

    本文将分别讲解经典的TCP协议建立连接(所谓的“3次握手”)和断开连接(所谓的“4次挥手”)的过程. 尽管TCP和UDP都使用相同的网络层(IP),TCP却向应用层提供与UDP完全不同的服务.TCP提 ...

  5. [转]iOS学习之UINavigationController详解与使用(三)ToolBar

    转载地址:http://blog.csdn.net/totogo2010/article/details/7682641 iOS学习之UINavigationController详解与使用(二)页面切 ...

  6. iOS学习之UINavigationController详解与使用(三)ToolBar

    1.显示Toolbar  在RootViewController.m的- (void)viewDidLoad方法中添加代码,这样Toobar就显示出来了. [cpp] view plaincopy [ ...

  7. JVM完整详解:内存分配+运行原理+回收算法+GC参数等

    不管是BAT面试,还是工作实践中的JVM调优以及参数设置,或者内存溢出检测等,都需要涉及到Java虚拟机的内存模型.内存分配,以及回收算法机制等,这些都是必考.必会技能. JVM内存模型 JVM内存模 ...

  8. XML详解:第三部分 XML解析

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  9. 完整具体解释GCD系列(二)dispatch_after;dispatch_apply;dispatch_once

    原创Blog,转载请注明出处 本文阅读的过程中,如有概念不懂,请參照前专栏中之前的文章,假设还有疑惑,请留言. 这是我关于GCD专栏的地址 http://blog.csdn.net/column/de ...

随机推荐

  1. 资料汇总--Web前端

    01.前端技能汇总 02.gitHub优秀前端资料分享 03.大前端 HTML Doctype作用?严格模式与混杂模式如何区分?它们有何意义? 1. <!DOCTYPE> 声明位于文档中的 ...

  2. C# ASP.NET Core使用HttpClient的同步和异步请求

    引用 Newtonsoft.Json // Post请求 public string PostResponse(string url,string postData,out string status ...

  3. webpack的学习感悟

    https://github.com/webpack/webpack    webpack gethub地址. http://webpack.github.io/   webpack 官网 前言 we ...

  4. redis(2)数据类型

    一.数据类型 redis的数据结构是key-value的键值对的形式,但是它和传统String-String的键值对形式不一样,它的value不仅仅是string类型,而是有着丰富的数据类型,如: 1 ...

  5. 把一个项目a生成后放在另一个项目b使用(b项目是例子中的ScreenWebPage_Tool)

    a项目属性---生成事件---后期生成事件命令行   xcopy /r /y  $(TargetDir)*.* $(SolutionDir)ScreenWebPage_Tool\bin\Debug\* ...

  6. asp.net 、C#实现微信企业号OAuth2认证

    以微信企业号作为入口的应用,几乎都会遇到需要应用系统中个人信息和微信用户关联问题.从而进行其他业务处理.目前所做项目采取在企业号通讯录添加自定义字段存入应用系统用户信息表中唯一标识UserGuid进行 ...

  7. C中的私有成员

    skynet_context声明在.h里 但定义在.c里面 外部使用的时候无法用ctx->handle获取私有成员,会提示解引用类型错误 必须用.h里函数获取ctx里属性.

  8. maven更改仓库地址

    安装maven后,maven的默认的仓库地址在  C:\Users\Administrator\.m2\repository 修改maven的仓库地址的步骤是,1.在某个盘符下建立一个文件夹,当做现在 ...

  9. webpack_hmr报错 cannot load 状态500

    使用vue-cli时,启动本地环境,然后页面没有关闭,直接切换到线上环境,过一会会发起一个http://xxx/__webpack_hmr请求,会报cannot load原因:它属于nodejs中的一 ...

  10. 【转载】javascript深入理解js闭包

    一.变量的作用域 要理解闭包,首先必须理解Javascript特殊的变量作用域. 变量的作用域无非就是两种:全局变量和局部变量. Javascript语言的特殊之处,就在于函数内部可以直接读取全局变量 ...