多线程并发流程控制之dispatch_group 有关函数
2024-09-24 15:02:37
A B C D 4个并发下载任务,怎样在第一时间知道任务全部完成?
dispatch_group 可以帮我们实现这样的控制。
上代码,看说明.
- dispatch_group_t group = dispatch_group_create();
- // 某个任务放进 group
- dispatch_group_async(group, dispatch_get_global_queue(0, 0), ^{
- // 任务代码1
- });
- dispatch_group_async(group, dispatch_get_global_queue(0, 0), ^{
- // 任务代码2
- });
- dispatch_group_notify(group, dispatch_get_main_queue(), ^{
- // 任务全部完成处理
- NSLog(@"isover");
- });
创建一个任务组,然后将异步操作放进组里面,在最后用notify 告知所有任务完成,并做相应处理,一般来说都是在主线程里面刷新UI来提示用户了。你如果不依赖UI放进子线程里面也是没有问题的。当然group同步的方式还有其他
- dispatch_async(dispatch_get_global_queue(0, 0), ^{
- for (int i = 0; i < 3; i ++)
- {
- dispatch_group_enter(group);
- // 任务代码i 假定任务 是异步执行block回调
- // block 回调执行
- dispatch_group_leave(group);
- // block 回调执行
- }
- });
- dispatch_group_wait(group, DISPATCH_TIME_FOREVER);
- dispatch_async(dispatch_get_main_queue(), ^{
- // 主线程处理
- });
首先我们异步执行,因为dispatch_group_wait函数是阻塞的,for里面安排了三个任务,这三个任务都是加载,在任务开始前 调用 enter,任务完成时调用leave,wait函数一直阻塞,直到它发现group里面的任务全部leave,它才放弃阻塞(任务全部完成),然后我们在主线程更新UI告知用户.
最新文章
- C# 7.0 新功能代码范例
- hdu 1032
- easyui form 方式提交数据
- error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏	E:\OCX
- copy
- Codeforces 525E Anya and Cubes
- select2简单例子
- maven的webapp产品热销部署eclipse,biz和其他子项目jar一揽子的解决方案无法找到!
- [Shell]随机数
- Linux笔记(五) - 用户管理命令
- sql 语句写的行列转换
- Membership ——入门基础
- selenium——键盘操作
- 用keytool制作证书并在tomcat配置https服务(二 )
- MVC中权限的知识点及具体实现代码
- Linux关机命令和重启命令
- 4-java 格式化输出
- ubuntu16.04 中文输入法
- oracle 日期时间函数
- 20155333 2016-2017-2 《Java程序设计》第十周学习总结