多线程并发控制dispatch_group
2017-03-14 12:48
295 查看
1、在开发中经常遇到调用多个接口请求数据完成后,再根据不同接口返回的数据调用另外的方法处理请求数据的情况。当然这种可以使用同步请求数据,然后做处理。这样就会按照程序先后执行。但是往往这种方式效率低下,会阻塞线程。为了解决问题通常会引入dispatch_group并发处理。
创建一个dispatch任务组,然后将异步操作放进组里面,在最后用notify 告知所有任务完成;只有当任务组里面的任务执行完后才会调用dispatch_group_notify方法。这种方式在下载图片的时候有广泛的应用。
2、但是当考虑到在每个异步任务中有网络请求,回调block这种情况时,上面的方式不能满足实际需求:
实际代码执行的情况是先执行dispatch_group_notify然后再执行回调block的方法;这样和需求,根据请求回调结果然后再执行dispatch_group_notify不一样。为了解决上面的需求问题我们引入:dispatch_group_enter(group)和dispatch_group_leave(group)。使用dispatch_group_enter和dispatch_group_leave,enter和leave必须配合使用,有几次enter就要有几次leave,否则group会一直存在。当所有enter的block都leave后,会执行dispatch_group_notify的block。这样就能够满足需求,同时又省去执行多个同步操作的时间:
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(@"last"); });
创建一个dispatch任务组,然后将异步操作放进组里面,在最后用notify 告知所有任务完成;只有当任务组里面的任务执行完后才会调用dispatch_group_notify方法。这种方式在下载图片的时候有广泛的应用。
2、但是当考虑到在每个异步任务中有网络请求,回调block这种情况时,上面的方式不能满足实际需求:
dispatch_group_t group = dispatch_group_create(); // 某个任务放进 group dispatch_group_async(group, dispatch_get_global_queue(0, 0), ^{ [_viewModel getPropertiesListById:id success:^(id obj) { NSLog(@"数据请求成功"); } failure:^(id obj) { NSLog(@"数据请求失败"); }]; });
实际代码执行的情况是先执行dispatch_group_notify然后再执行回调block的方法;这样和需求,根据请求回调结果然后再执行dispatch_group_notify不一样。为了解决上面的需求问题我们引入:dispatch_group_enter(group)和dispatch_group_leave(group)。使用dispatch_group_enter和dispatch_group_leave,enter和leave必须配合使用,有几次enter就要有几次leave,否则group会一直存在。当所有enter的block都leave后,会执行dispatch_group_notify的block。这样就能够满足需求,同时又省去执行多个同步操作的时间:
dispatch_group_t group = dispatch_group_create(); dispatch_queue_t globalQueue=dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0); dispatch_group_enter(group); dispatch_group_async(group, globalQueue, ^{ [_viewModel getPropertiesListById:id success:^(id obj) { dispatch_group_leave(group); } failure:^(id obj) { dispatch_group_leave(group); }]; }); dispatch_group_enter(group); dispatch_group_async(group, globalQueue, ^{[_viewModel getPropertiesListById:id success:^(id obj) { dispatch_group_leave(group); } failure:^(id obj) { dispatch_group_leave(group); }]; }); dispatch_group_notify(group, dispatch_get_main_queue(), ^{ NSLog(@"数据请求失败"); });
相关文章推荐
- 多线程并发流程控制之dispatch_group 有关函数
- 多线程并发流程控制之dispatch_group 有关函数
- 多线程并发流程控制之dispatch_group 有关函数
- ios 多线程控制线程并发数、GCD之dispatch_group、GCD信号量
- dispatch_group控制多个并发请求
- GCD 信号量控制并发(dispatch_semaphore)以及dispatch_group_async
- GCD 信号量控制并发 (dispatch_semaphore)
- java并发包学习系列:几个多线程控制工具类(草稿)
- java多线程并发控制之ThreadLocal
- 项目中怎么控制多线程高并发访问 .
- java多线程并发控制之ThreadLocal
- iOS dispatch_group 串行队列,并行队列 多线程
- 多线程时控制并发数据库操作的思路
- 多线程并发 synchronized对象锁的控制与优化
- 多线程----派遣组技术 dispatch_group_t group
- 实现 Java 多线程并发控制框架
- 实现 Java 多线程并发控制框架
- JAVA多线程并发变量控制方法之volatile修饰工作原理
- 在CGD中快速实现多线程的并发控制
- GCD 信号量控制并发 (dispatch_semaphore)