原创Blog,转载请注明出处
一、dispatch_group
把一组任务提交到队列中,这些队列可以不相关,然后坚挺这组任务完成的事件。
几个用到的函数
1、dispatch_group_create创建一个调度任务组
2、dispatch_group_async 把一个任务异步提交到任务组里
参数:
group
提交到的任务组,这个任务组的对象会一直持续到任务组执行完毕
queue
提交到的队列,任务组里不同任务的队列可以不同
block
提交的任务
3、dispatch_group_enter/dispatch_group_leave
这两个方法显示的讲任务组中的任务未执行完毕的任务数目加减1,这种方式用在不使用dispatch_group_async来提交任务,注意:这两个函数要配合使用,有enter要有leave,这样才能保证功能完整实现。也可以用这对函数来让一个闭包关联多个Group
4、dispatch_group_notify 用来监听任务组事件的执行完毕
参数:
group
监听的任务组
queue
执行完毕的这个闭包所在的队列
block
执行完毕所响应的任务
5、dispatch_group_wait 设置等待时间,在等待时间结束后,如果还没有执行完任务组,则返回。返回0代表执行成功,非0则执行失败
二、完整的代码解析,模拟提交三个下载任务
可以看到输出为
这里task1提交到全局队列中,task2和task3提交到用户穿件的串行队列中,所以task1和task2同时输出,task3在task2结束两秒后输出。
如果把注释那行取消,会等待一段时间,再返回,读者可以自己去试验下
三、关于如何使用dispatch_group_enter/dispatch_group_leave如何使用
输出
可以看到,同步进行了下载,这里的任务是串行的,实际消耗时间9s。当然,也可以把下载的任务提交到异步队列中
这样的话,输出是
由于三个模拟的下载任务是并行的,所以实际消耗时间3s
一、dispatch_group
把一组任务提交到队列中,这些队列可以不相关,然后坚挺这组任务完成的事件。
几个用到的函数
1、dispatch_group_create创建一个调度任务组
2、dispatch_group_async 把一个任务异步提交到任务组里
参数: group 提交到的任务组,这个任务组的对象会一直持续到任务组执行完毕
queue 提交到的队列,任务组里不同任务的队列可以不同
block 提交的任务
3、dispatch_group_enter/dispatch_group_leave
这两个方法显示的讲任务组中的任务未执行完毕的任务数目加减1,这种方式用在不使用dispatch_group_async来提交任务,注意:这两个函数要配合使用,有enter要有leave,这样才能保证功能完整实现。也可以用这对函数来让一个闭包关联多个Group
4、dispatch_group_notify 用来监听任务组事件的执行完毕
参数: group 监听的任务组
queue 执行完毕的这个闭包所在的队列
block 执行完毕所响应的任务
5、dispatch_group_wait 设置等待时间,在等待时间结束后,如果还没有执行完任务组,则返回。返回0代表执行成功,非0则执行失败
二、完整的代码解析,模拟提交三个下载任务
可以看到输出为
这里task1提交到全局队列中,task2和task3提交到用户穿件的串行队列中,所以task1和task2同时输出,task3在task2结束两秒后输出。
如果把注释那行取消,会等待一段时间,再返回,读者可以自己去试验下
三、关于如何使用dispatch_group_enter/dispatch_group_leave如何使用
输出
可以看到,同步进行了下载,这里的任务是串行的,实际消耗时间9s。当然,也可以把下载的任务提交到异步队列中
这样的话,输出是
由于三个模拟的下载任务是并行的,所以实际消耗时间3s