使用Dispatch_Group管理相互依赖的操作

      我们在请求网络数据的时候,有时候多个接口之间存在依赖,如果嵌套着来编写代码就显得代码逻辑复杂,不方便阅读和管理,经过查找网上资料,本人总结了两种方式方便于大家使用,也方便自己记忆查找。

第一种

#pragma mark 带有异步请求的任务不适合用此方式

- (void)creatDispatchGroup{

//    创建 group 和 queue

dispatch_group_t getDataGroup = dispatch_group_create();

dispatch_queue_t getDataQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);

//    将任务添加到 group 和指定的 queue

dispatch_group_async(getDataGroup, getDataQueue, ^{

[self ML_DeviceData];

});

dispatch_group_async(getDataGroup, getDataQueue, ^{

[self DW_DeviceData];

});

//    不阻塞当前线程,马上返回

dispatch_queue_t notifyQueue = dispatch_get_main_queue();

dispatch_group_notify(getDataGroup, notifyQueue, ^{

CLog(@"队列执行完毕---------");

});

//    阻塞当前线程,直到group中的任务全部完成才进行返回

//    dispatch_group_wait(getDataGroup, DISPATCH_TIME_FOREVER);

}

      上述代码中的适合向group种添加同步执行的代码,但我们的网络请求大多数都是异步请求的,所以对于进行异步网络请求的操作不适合使用这种队列,因为当我们得到"队列执行完毕----"的输出的时候,这时候数据可能还没有返回,也就无法进行下一步操作,使用的时候大家一定要注意。

第二种

#pragma mark  适合线程组中带有异步请求的调用 等待所有异步请求完全结束才调用回掉block

- (void)creatNewDispatchGroup{

//    创建 group 和 queue

dispatch_group_t getDataGroup = dispatch_group_create();

//    dispatch_queue_t getDataQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);

//    数据请求1

[POSTData ML_getDataWithURL:defaultMLurl andSentDic:@{@"cuId":userCUID} objectName:@"getAllPuList" andMethodName:@"getObject" success:^(id responseData) {

CLog(@"%@",responseData);

dispatch_group_leave(getDataGroup);

} fail:^(NSError *error) {

}];

//    数据请求2

dispatch_group_enter(getDataGroup);

[POSTData getResponseDataWithURL:defaultWebServiceUrl andsentDataArr:sentArr andMethodName:@"QueryEquipment" andKey:defaultKey isPMKEY:YES success:^(id responseData) {

CLog(@"%@",responseData);

dispatch_group_leave(getDataGroup);

} fail:^(NSError *error) {

}];

dispatch_group_notify(getDataGroup, dispatch_get_main_queue(), ^{

CLog(@"完成所有请求");

});

}

      这种方法可以满足我们的需求,当第一个异步请求完成结束后,才会接着紧着进行第二个异步请求,当所有请求完全结束后我们的dispatch_group_notify方法才会得到回调。

总结

      所以进行多个相互依赖的操作的时候,如果是同步进行操作我们可以使用第一种方式,如果group中包含异步操作,我们可以使用第二种方式。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • NSThread 第一种:通过NSThread的对象方法 NSThread *thread = [[NSThrea...
    攻城狮GG阅读 4,316评论 0 3
  • 谈到iOS多线程,一般都会谈到四种方式:pthread、NSThread、GCD和NSOperation。其中,苹...
    攻城狮GG阅读 2,425评论 0 3
  • GCD (Grand Central Dispatch) :iOS4 开始引入,使用更加方便,程序员只需要将任务添...
    池鹏程阅读 5,188评论 0 2
  • 一阵轻描淡写的风 引起冬日的一场雪崩 用心守护的城堡轰然坍塌 伪装的坚强无处遁形 风吹散枯萎的落叶 记忆便随处飘零...
    A安之若素A阅读 1,549评论 0 0
  • 今日和往常一样在柜台办理业务,突然来了一位中年大妈,个不高,略白净,架着一副金丝边眼镜,口音不是特别清楚,见面例行...
    克里斯丁阅读 1,643评论 0 1

友情链接更多精彩内容