如何等到嵌套的block执行完后再执行其他代码?

时间:2022-10-21 19:56:41

现在有一个单例 Manage.h、Manage.m  里面有你封装的一个请求服务器数据的方法。

例如:-(void)manageRequestWithUrl:(NSURL*)urlName handleBlock(void(^)(NSData *data,NSError* error)) handle{

    

    NSURLRequest *request=[NSURLRequest requestWithURL:url];

    NSURLSessionDataTask *dataTask=[[self mySession] dataTaskWithRequest:request         completionHandler:^(NSData * _Nullable data, NSURLResponse * _Nullable response,     NSError * _Nullable error) {

        handle(data,error);

    }];

    [dataTask resume];



}注意 这个封装函数本身就是个block 而用nsurlsession  请求返回的数据也是block。


现在你要在 类A.m 里 同时请求3个接口 然后把结果放到一个数组里 并刷新TableView;

A.m 里 你可以用 单例 Manage.h 封装好的放法 。如何使这三个请求并行执行 而且刚好是3个都请求完了以后才刷新TableView 呢?

这时就要用到 强大的GCD了 。 利用group 和 queue 就能很好的解决这个问题。

A.m 里 调用3个请求:

            1. 创建队列,可以用全局队列 也可以 自己创建一个,自己创建的不会加入到全局队列中。

            2.创建组。

            3.dispatch_group_enter(mygroup); 

       dispatch_async(myqueue, ^{执行的方法});                                              dispatch_group_leave(mygroup); 执行的方法完成以后 离开组。 最后执行

       dispatch_group_notify(mygroupdispatch_get_main_queue(), ^{});


    myqueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_HIGH, 0);

    mygroup = dispatch_group_create();


        dispatch_group_enter(mygroup);

                dispatch_async(myqueue, ^{

        NSString *urlStr =@“请求1”;

        

        [Manage requestUrl:urlStr withData:^(NSData *data, NSError *error) {

            if (!error) {

                NSMutableDictionary *dataDic = [NSJSONSerialization JSONObjectWithData:data

                                                                               options:NSJSONReadingMutableContainers

                                                                                 error:nil];

                dispatch_group_leave(mygroup);

        }];

        

    });

   

    dispatch_group_enter(mygroup);

                dispatch_async(myqueue, ^{

        NSString *urlStr =@“请求2”;

        

        [Manage requestUrl:urlStr withData:^(NSData *data, NSError *error) {

            if (!error) {

                NSMutableDictionary *dataDic = [NSJSONSerializationJSONObjectWithData:data

                                                                               options:NSJSONReadingMutableContainers

                                                                                 error:nil];

                dispatch_group_leave(mygroup);

        }];

        

    });

    

    dispatch_group_enter(mygroup);

                dispatch_async(myqueue, ^{

        NSString *urlStr =@“请求3”;

        

        [Manage requestUrl:urlStr withData:^(NSData *data, NSError *error) {

            if (!error) {

                NSMutableDictionary *dataDic = [NSJSONSerializationJSONObjectWithData:data

                                                                               options:NSJSONReadingMutableContainers

                                                                                 error:nil];

                dispatch_group_leave(mygroup);

        }];

        

    });

最后执行!!!

    dispatch_group_notify(mygroup, dispatch_get_main_queue(), ^{

        [_wTable reloadData];//刷新

    });


这样就能等到 3个请求都返回数据以后再刷新 ,上面这种方法 属于 手动管理gourp  还有一种是 交给系统来管理:
例如:

 dispatch_queue_t queue = dispatch_get_global_queue(0, 0);

    dispatch_group_t group1 = dispatch_group_create();

    dispatch_group_async(group1, queue, ^{

        NSLog(@"A买水果");

    });

    dispatch_group_async(group1, queue, ^{

        NSLog(@"B买烤鸭");


    });

    dispatch_group_async(group1, queue, ^{

        NSLog(@"C买扑克");

  

    });

    dispatch_group_async(group1, queue, ^{

        NSLog(@"D买水");

   

    });

    dispatch_group_notify(group1, queue, ^{

        NSLog(@"Let's go!");

    });