iOS-多线程之多接口请求(有序,无序)

需求:开发过程中某个界面多个请求, 可有序,或者无序请求后更新UI
情景一:多个网络请求执行(无序)完后,在执行其他操作
#define GlobalQueue dispatch_get_global_queue(0, 0)

#define MainQueue dispatch_get_main_queue()

1.队列组group + notify
思路:group其实就是管理指定queue中任务的。在这里通过调用dispatch_group_notify方法,等待group中管理queue的任务执行完毕后,会在该group指定的队列中执行block内部的代码。

- (void)multipleRequest_NoOrder_after_executeOtherTask_byGroupNotify {
    dispatch_group_t group = dispatch_group_create();
    dispatch_group_async(group, GlobalQueue, ^{
        sleep(1);
        NSLog(@"网络请求1");
    });
    dispatch_group_async(group, GlobalQueue, ^{
        sleep(1);
        NSLog(@"网络请求2");
    });
    dispatch_group_async(group, GlobalQueue, ^{
        sleep(1);
        NSLog(@"网络请求3");
    });
    dispatch_group_async(group, GlobalQueue, ^{
        sleep(1);
        NSLog(@"网络请求4");
    });
    //当group中的任务执行完后,会调用
    dispatch_group_notify(group, MainQueue, ^{
        NSLog(@"更新UI");
    });
}

无序请求

2.队列组group

- (void)text_gcd{
    
    weakSelf(self);
    dispatch_group_t group = dispatch_group_create();
    dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
    
    
    // 主线程 顺序执行。dispatch_sync
    // 异步线程 顺序打乱 dispatch_async
    
    dispatch_group_enter(group);
    dispatch_sync(queue, ^{
        SWLog(@"开始请求1111111");
        [weakSelf get_TaskData:^{
            SWLog(@"请求完成 11111111");
            dispatch_group_leave(group);
        }];
    });

    dispatch_group_enter(group);
    dispatch_sync(queue, ^{
         SWLog(@"开始请求2222222");
        [weakSelf get_TaskData:^{
            SWLog(@"请求完成 222222222");
            dispatch_group_leave(group);
        }];
    });

    dispatch_group_enter(group);
    dispatch_sync(queue, ^{
        SWLog(@"开始请求33333");
        [weakSelf get_TaskData:^{
            SWLog(@"请求完成 3333333");
            dispatch_group_leave(group);
        }];
    });
    
    dispatch_group_notify(group, dispatch_get_main_queue(), ^{
        SWLog(@"请求上面123 后走这里,回到主线程 刷新UI");
    });
    
}
2019-03-06 16:22:30.365326+0800 MVVM+RAC[7201:533505] < ViewController.m:(109) > 开始请求1111111
2019-03-06 16:22:30.365474+0800 MVVM+RAC[7201:533505] < ViewController.m:(121) > 开始请求2222222
2019-03-06 16:22:30.365560+0800 MVVM+RAC[7201:533505] < ViewController.m:(130) > 开始请求33333
2019-03-06 16:22:30.463713+0800 MVVM+RAC[7201:533710] [] nw_proxy_resolver_create_parsed_array PAC evaluation error: NSURLErrorDomain: -1004
2019-03-06 16:22:32.447209+0800 MVVM+RAC[7201:533505] < ViewController.m:(111) > 请求完成 11111111
2019-03-06 16:22:32.447537+0800 MVVM+RAC[7201:533505] < ViewController.m:(123) > 请求完成 222222222
2019-03-06 16:22:32.447944+0800 MVVM+RAC[7201:533505] < ViewController.m:(132) > 请求完成 3333333
2019-03-06 16:22:32.448110+0800 MVVM+RAC[7201:533505] < ViewController.m:(138) > 请求上面123 后走这里,回到主线程 刷新UI


3 .NSOperation + NSOperationQueue
思路:通过NSBlockOperation创建多个任务,将任务添加到NSBlockOperationQueue中.通过调用addBarrierBlock方法,会等到将任务添加到NSBlockOperationQueue中所有的任务执行完毕后,才会执行block中的代码。

 - (void)multipleRequest_NoOrder_after_executeOtherTask_byOperation {
     NSBlockOperation *block1 = [NSBlockOperation blockOperationWithBlock:^{
         sleep(1);
         NSLog(@"网络请求1");
     }];
     NSBlockOperation *block2 = [NSBlockOperation blockOperationWithBlock:^{
         sleep(1);
         NSLog(@"网络请求2");
     }];
     NSBlockOperation *block3 = [NSBlockOperation blockOperationWithBlock:^{
         sleep(1);
         NSLog(@"网络请求3");
     }];
     NSBlockOperation *block4 = [NSBlockOperation blockOperationWithBlock:^{
         sleep(1);
         NSLog(@"网络请求4");
     }];
     
     NSOperationQueue *queue = [[NSOperationQueue alloc] init];
     //设置最大并发数
     queue.maxConcurrentOperationCount = [NSProcessInfo processInfo].activeProcessorCount;
     //waitUntilFinished:是否等待queue中的任务执行完后,才执行后面的代码。会阻塞当前线程
     [queue addOperations:@[block1,block2,block3,block4] waitUntilFinished:NO];
     
     //当queue中的所有任务执行完后,会调用
     [queue addBarrierBlock:^{
         NSLog(@"更新UI");
     }];
 }

二、RAC(ReactiveCocoa(其简称为RAC)是由GitHub开源的一个应用于iOS和OS X开发的新框架。RAC具有函数式编程响应式编程的特性)
pod 'ReactiveObjC', '~> 3.0.0' //建议纯oc代码使用ReactiveObjC

//信号量请求 类似gcd
- (void)liftSelector{
    RACSignal *signal1 = [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
        SWLog(@"请求111");
        [subscriber sendNext:@"11111成功"];
        return nil;
    }];
    
    RACSignal *signal2 = [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {
         SWLog(@"请求2222");
        [subscriber sendNext:@"222222成功"];
        return nil;
    }];
    
    [self rac_liftSelector:@selector(refeshUI::) withSignals:signal1,signal2, nil];
    
}
-(void)refeshUI:(id)one :(id)two{
    NSLog(@"%@---%@",one,two);
}


Log 输出
2019-03-07 14:14:29.163017+0800 MVVM+RAC[9845:694036] < ViewController.m:(115) > 请求111
2019-03-07 14:14:32.189107+0800 MVVM+RAC[9845:694036] < ViewController.m:(121) > 请求2222
2019-03-07 14:14:34.192020+0800 MVVM+RAC[9845:694036] 11111成功---222222成功

怎么样,RAC好用吧~,我会另外写一篇文章专门简单学习RAC的

如果对你有帮助, 随手一❤️,如果写的不对的地方,麻烦指出~哈哈,感谢
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 基本概念 进程:进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,在iOS系统中,开启一个应用...
    xiaoyuyang612阅读 1,871评论 0 1
  • 文用来介绍 iOS 多线程中 GCD 的相关知识以及使用方法。通过本文,您将了解到: 1. GCD 简介 2. G...
    晓_我想去环游世界阅读 1,159评论 2 8
  • 每年回家同学聚会,聊起生活,貌似待在家乡的同学、朋友早已坐拥视野宽阔、坐南朝北的大房子,过起了悠哉悠哉的小日子,再...
    趣拾家阅读 644评论 0 12
  • 在那个遥远的山村,发生了不少匪夷所思的故事。 01 *德宝迷失记* 德宝在小学五年级的时候是班长,长的帅,学习好,...
    无知无觉晓阅读 422评论 0 1