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. Xcode日常使用

    1.构建输出目录(Preferences->Locations->Locations)当选择为Default时,Derived Data的目录为~/Library/Developer/Xc ...

  2. java 如何下载jar包

    随着maven工具的使用,我们已经不再需要辛苦的找jar包,也不需要再买会员去下载jar包,但是还有一些同学,不知道怎么下载jar包,下面我给大家介绍一下,如何潇洒的找到自己想要的jar包. 首先,访 ...

  3. Java - 生成keystore

    有个需求,说要在生成PDF文件时加上signature.操作PDF容易,用: <dependency> <groupId>com.itextpdf</groupId> ...

  4. Vue-Router的使用(一)

    1.首先,安装vue-router npm install vue-router --save-dev 2.创建一个route.js文件 // 1. 定义路由组件 // 可以自己写的,或者导入的,大部 ...

  5. phpmyadmin登录报错crypt_random_string requires at least one symmetric cipher be loaded 解决方法

    通过phpmyadmin登陆时提示以下错误: phpmyadmin crypt_random_string requires at least one symmetric cipher be load ...

  6. NOI.AC NOIP模拟赛R3解题报告

    心路历程 预计得分:\(100+100+50=250\) 实际得分:\(10 +100 +50 = 160\) 三道原题,真好.T2做过,T1写了个错误思路,T3写了写50分状压dp. 整场考试实际在 ...

  7. js 两个小括号 ()() 的用法

    实现一个函数fn, 使fn(1)(2)的结果为两个参数的和,刚开始没反应过来,其实细细一想第二个括号就是函数再调用的问题,废话不多说,代码奉上: var fn = function(n) { func ...

  8. 新手必需用!大道至简的前端编辑器Sublime Text

    很多人在进入学习前端的时候(包括我自己),除了选择学习合适的技术,还需要一个得(自)心(己)应(喜)手(欢)的开发工具,一个得心应手的开发工具除了可以令你的效率大大提高,也可以令你在写代码的时候,心情 ...

  9. Unity导出APk出错解决方法二

    错误提示(需得打开编辑器log文件才能看到全部log,Unity3d只显示一部分): Error building Player: CommandInvokationFailure: Unable t ...

  10. addEventListener(event, function, useCapture) 简记

    监听事件方法:addEventListener(<event-name>, <callback>, <use-capture>) 移除监听事件方法:removeEv ...