完整详解GCD系列(三)dispatch_group
http://blog.csdn.net/hello_hwc/article/details/41409135
一、dispatch_group
把一组任务提交到队列中,这些队列可以不相关,然后坚挺这组任务完成的事件。
几个用到的函数
1、dispatch_group_create创建一个调度任务组
- func dispatch_group_create() -> dispatch_group_t!
2、dispatch_group_async 把一个任务异步提交到任务组里
- func dispatch_group_async(_ group: dispatch_group_t!,
- _ queue: dispatch_queue_t!,
- _ block: dispatch_block_t!)
参数: group 提交到的任务组,这个任务组的对象会一直持续到任务组执行完毕
queue 提交到的队列,任务组里不同任务的队列可以不同
block 提交的任务
3、dispatch_group_enter/dispatch_group_leave
- func dispatch_group_enter(_ group: dispatch_group_t!)
- func dispatch_group_leave(_ group: dispatch_group_t!)
这两个方法显示的讲任务组中的任务未执行完毕的任务数目加减1,这种方式用在不使用dispatch_group_async来提交任务,注意:这两个函数要配合使用,有enter要有leave,这样才能保证功能完整实现。也可以用这对函数来让一个闭包关联多个Group
4、dispatch_group_notify 用来监听任务组事件的执行完毕
- func dispatch_group_notify(_ group: dispatch_group_t!,
- _ queue: dispatch_queue_t!,
- _ block: dispatch_block_t!)
参数: group监听的任务组
queue 执行完毕的这个闭包所在的队列
block 执行完毕所响应的任务
5、dispatch_group_wait 设置等待时间,在等待时间结束后,如果还没有执行完任务组,则返回。返回0代表执行成功,非0则执行失败
- long dispatch_group_wait ( dispatch_group_t group, dispatch_time_t timeout );
二、完整的代码解析,模拟提交三个下载任务
- class ViewController: UIViewController{
- override func viewDidLoad(){
- super.viewDidLoad()
- var hwcGroup = dispatch_group_create()//创建group
- var globalQueueDefault = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0)//全局队列,这个队列为并行队列
- var userCreateQueue = dispatch_queue_create("com.test.helloHwc",DISPATCH_QUEUE_SERIAL)//创建一个用户队列,这个队列为串行队列
- downLoadTask1(group: hwcGroup,queue: globalQueueDefault)
- downLoadTask2(group: hwcGroup,queue: userCreateQueue)
- downLoadTask3(group: hwcGroup,queue: userCreateQueue)
- //letresult = dispatch_group_wait(hwcGroup,DISPATCH_TIME_FOREVER)
- dispatch_group_notify(hwcGroup,dispatch_get_main_queue()){
- NSLog("Group tasks are done")
- }
- println("Now viewDidLoad is done")
- }
- func downLoadTask1(#group:dispatch_group_t,queue:dispatch_queue_t){
- dispatch_group_async(group,queue){
- sleep(3)
- NSLog("Task1 is done")
- }
- }
- func downLoadTask2(#group:dispatch_group_t,queue:dispatch_queue_t){
- dispatch_group_async(group,queue){
- sleep(3)
- NSLog("Task2 is done")
- }
- }
- func downLoadTask3(#group:dispatch_group_t,queue:dispatch_queue_t){
- dispatch_group_async(group,queue){
- sleep(3)
- NSLog("Task3 is done")
- }
- }
- override func didReceiveMemoryWarning(){
- super.didReceiveMemoryWarning()
- }
- }
可以看到输出为
- Now viewDidLoad is done
- Task2 is done
- Task1 is done
- Task3 is done
- Group task is done
这里task1提交到全局队列中,task2和task3提交到用户穿件的串行队列中,所以task1和task2同时输出,task3在task2结束两秒后输出。
如果把注释那行取消,会等待一段时间,再返回,读者可以自己去试验下
三、关于如何使用dispatch_group_enter/dispatch_group_leave如何使用
- <pre name="code" class="plain">class ViewController: UIViewController{
- override func viewDidLoad(){
- super.viewDidLoad()
- var hwcGroup = dispatch_group_create()//创建group
- var globalQueueDefault = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0)//全局队列,这个队列为并行队列
- for index:UInt32 in 1...3{
- dispatch_group_enter(hwcGroup)//提交了一个任务,任务数目加1
- manualDownLoad(index){
- println("Task\(index) is done")
- dispatch_group_leave(hwcGroup)//完成一个任务,任务数目减1
- }
- }
- let result = dispatch_group_wait(hwcGroup,DISPATCH_TIME_FOREVER)//等待直到完成
- dispatch_group_notify(hwcGroup,dispatch_get_main_queue()){
- println("Group tasks are done")
- }
- println("Now viewDidLoad is done")
- }
- func manualDownLoad(num:UInt32,block:()->()){
- println("Downloading task\(num)")
- sleep(num)
- block()
- }
- override func didReceiveMemoryWarning(){
- super.didReceiveMemoryWarning()
- }
- }
输出
- Downloading task1
- Task1 is done
- Downloading task2
- Task2 is done
- Downloading task3
- Task3 is done
- Now viewDidLoad is done
- Group is done
可以看到,同步进行了下载,这里的任务是串行的,实际消耗时间9s。当然,也可以把下载的任务提交到异步队列中
- class ViewController: UIViewController{
- override func viewDidLoad(){
- super.viewDidLoad()
- var hwcGroup = dispatch_group_create()//创建group
- var globalQueueDefault = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0)//全局队列,这个队列为并行队列
- for index:UInt32 in 1...3{
- dispatch_group_enter(hwcGroup)//提交了一个任务,任务数目加1
- manualDownLoad(index,queue:globalQueueDefault){
- NSLog("Task\(index) is done")
- dispatch_group_leave(hwcGroup)//完成一个任务,任务数目减1
- }
- }
- dispatch_group_notify(hwcGroup,dispatch_get_main_queue()){
- NSLog("Group tasks are done")
- }
- NSLog("Now viewDidLoad is done")
- }
- func manualDownLoad(num:UInt32,queue:dispatch_queue_t, block:()->()){
- dispatch_async(queue){
- NSLog("Downloading task\(num)")
- sleep(num)
- block()
- }
- }
- override func didReceiveMemoryWarning(){
- super.didReceiveMemoryWarning()
- }
- }
这样的话,输出是
- Downloading task1
- Downloading task2
- Downloading task3
- Now viewDidLoad is done
- Task1 is done
- Task2 is done
- Task3 is done
由于三个模拟的下载任务是并行的,所以实际消耗时间3s
完整详解GCD系列(三)dispatch_group的更多相关文章
- 「视频直播技术详解」系列之七:直播云 SDK 性能测试模型
关于直播的技术文章不少,成体系的不多.我们将用七篇文章,更系统化地介绍当下大热的视频直播各环节的关键技术,帮助视频直播创业者们更全面.深入地了解视频直播技术,更好地技术选型. 本系列文章大纲如下: ...
- CocoaPods详解之(三)----制作篇
CocoaPods详解之----制作篇 作者:wangzz 原文地址:http://blog.csdn.net/wzzvictory/article/details/20067595 转载请注明出处 ...
- 第6章 传输层(详解TCP的三次握手与四次挥手)
第6章 传输层 传输层简介 传输层为网络应用程序提供了一个接口,并且能够对网络传输提供了可选的错误检测.流量控制和验证功能.TCP/IP传输层包含很多有用的协议,能够提供数据在网络传输所需的必要寻址信 ...
- 详解TCP的三次握手四次断开
本文将分别讲解经典的TCP协议建立连接(所谓的“3次握手”)和断开连接(所谓的“4次挥手”)的过程. 尽管TCP和UDP都使用相同的网络层(IP),TCP却向应用层提供与UDP完全不同的服务.TCP提 ...
- [转]iOS学习之UINavigationController详解与使用(三)ToolBar
转载地址:http://blog.csdn.net/totogo2010/article/details/7682641 iOS学习之UINavigationController详解与使用(二)页面切 ...
- iOS学习之UINavigationController详解与使用(三)ToolBar
1.显示Toolbar 在RootViewController.m的- (void)viewDidLoad方法中添加代码,这样Toobar就显示出来了. [cpp] view plaincopy [ ...
- JVM完整详解:内存分配+运行原理+回收算法+GC参数等
不管是BAT面试,还是工作实践中的JVM调优以及参数设置,或者内存溢出检测等,都需要涉及到Java虚拟机的内存模型.内存分配,以及回收算法机制等,这些都是必考.必会技能. JVM内存模型 JVM内存模 ...
- XML详解:第三部分 XML解析
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- 完整具体解释GCD系列(二)dispatch_after;dispatch_apply;dispatch_once
原创Blog,转载请注明出处 本文阅读的过程中,如有概念不懂,请參照前专栏中之前的文章,假设还有疑惑,请留言. 这是我关于GCD专栏的地址 http://blog.csdn.net/column/de ...
随机推荐
- 【Hadoop系列】linux SSH原理解析
本文中斜体加粗代表shell指令,操作环境 CentOS6.5 linux root免密码登录链接:[Hadoop系列]linux下 root用户免密码登录远程主机 ssh. linux 非root用 ...
- request对象域和转发
1.request是一个域对象,具备以下方法 setAttribute(string name,Object O) getAttribute(String name) removeAttribute( ...
- Java-----思想认识
1.1 Java封装性思想的初步理解 从项目需求的角度出发,建立各个模块化的类,各个模块暂时不需要具体的方法描述,只需要各个模块的理想到位. 以银行项目为例.初步设想需要三个模块:银行(Bank类). ...
- ccf-201712-2 游戏
问题描述 有n个小朋友围成一圈玩游戏,小朋友从1至n编号,2号小朋友坐在1号小朋友的顺时针方向,3号小朋友坐在2号小朋友的顺时针方向,--,1号小朋友坐在n号小朋友的顺时针方向. 游戏开始,从1号小朋 ...
- Dockerfile定制镜像
一.Dockerfile是什么? 镜像定制实质就是定制每一层所添加的配置.文件. Dockerfile就是一个脚本来构建和定制镜像,把每一层的修改.安装.构建.操作都写入脚本.以此来解决体积.镜像构建 ...
- [TJOI2007]小朋友
题面 Luogu Sol 弦图最大独立集 做法见上篇博客 # include <bits/stdc++.h> # define RG register # define IL inline ...
- Java Struts2 (一)
一.Struts2简介 1.Struts2概述 Struts2是Apache发行的MVC开源框架.注意:它只是表现层(MVC)框架. 2.Struts2的来历 Struts1:也是apache开发的一 ...
- hdu 1162 Eddy's picture (Kruskal 算法)
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1162 Eddy's picture Time Limit: 2000/1000 MS (Java/Ot ...
- 02_NIO简单实例
[一个用NIO实现的客户端向服务端单向通信的例子] [服务端程序] package com.nio.test; import java.io.IOException; import java.net. ...
- Spring Boot Async异步执行
异步调用就是不用等待结果的返回就执行后面的逻辑,同步调用则需要等带结果再执行后面的逻辑. 通常我们使用异步操作都会去创建一个线程执行一段逻辑,然后把这个线程丢到线程池中去执行,代码如下: Execut ...