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. docker创建nginx镜像

    注意:此处不是用的dockerfile创建的镜像,只是用来搞一搞 首先你的系统里面要安装docker,这里就不重复介绍了,可以看之前的文章: 然后再搞一个基础镜像 docker pull regist ...

  2. C++运行符重载、友元函数

    Complex.h #pragma once #include <iostream> using namespace std; //表示一个复数 class Complex { priva ...

  3. java线程总结1--线程的一些概念基础以及线程状态

    在编程中,很多时候,我们需要计算机同时处理多件事情,例如说,就拿我相对最熟悉的web服务来说,web程序必须支持多用户访问,要不然如果你的用户只能支持一个用户在线访问,其他用户只能以排队的形式等待,估 ...

  4. 七、集成swagger2

    1.添加依赖 <!-- swager2 --> <dependency> <groupId>io.springfox</groupId> <art ...

  5. POJ 1185 炮兵阵地 经典的 状态压缩dp

    炮兵阵地 Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 16619   Accepted: 6325 Description ...

  6. 十二 NIO和IO

    NIO和IO的区别,应用场景? NIO和IO的主要区别 IO NIO 面向流 面向缓冲 阻塞IO 非阻塞IO 无 选择器 面向流和面向缓冲 Java NIO和IO之间第一个最大的区别是,IO是面向流的 ...

  7. 【转】JSON.parse()与JSON.stringify()的区别

    JSON.parse()[从一个字符串中解析出json对象] 例子: //定义一个字符串 var data='{"name":"goatling"}' //解析 ...

  8. phpmyadmin数据表结构没有显示注释列

    新开的一个项目,用phpmyadmin作为图形化操作数据库工具.创建数据表时为其每列添加好注释,浏览数据表内容有显示注释内容,但是查看数据表结构没有显示注释列,不方便直观查看数据表每列的意思. 上网搜 ...

  9. python----openpyxl模块

    openpyxl 模块 1.openpyxl的写 from openpyxl import Workbook wb = Workbook() # 方式一: 默认创建sheet在最后 wb1 = wb. ...

  10. 多盟、Testin云测、K9test,助阵阿里云1218 移动开发者狂欢

    经过双十一.双十二全民剁手狂欢后,阿里巴巴旗下的云计算业务,也为IT程序员们打造一场独特的盛宴. 阿里云计算12月18日对旗下主力云计算产品进行打折促销,云服务商.风投机构等都将参与到这场狂欢中.“我 ...