美文网首页
使用调度组同时处理多个任务

使用调度组同时处理多个任务

作者: Brice_Zhao | 来源:发表于2016-10-18 00:06 被阅读35次

假设你的应用在启动时必须向服务端进行一连串的请求.这些请求可能是获取配置信息.举个例子,当你的应用启动时可能会向服务端请求一些配置信息.这个配置信息可能需要多个请求组合而成.

你想通过调用一个方法去启动这些请求,然后全部请求完成后,在一个completion block里面完成你的业务逻辑. 但是这些请求相互间没有什么联系,我们应该如何做呢? 常见的方式是使用调度组( dispatch group )来实现.

初始化一个dispatch group

dispatch_group_t serviceGroup = dispatch_group_create();

向dispatch group中添加任务

1. 是在这个dispatch group中添加你的代码块,然后这些代码块会运行在你指定的queue中.
dispatch_group_async(serviceGroup,queue,^{
    // some work here
});

通过这样的方式我们可以:请求之后可以马上返回我们想要的数据,然后每个请求中都有自己的completion block。因为,当我们的“任务”完成的时候,dispatch group 会马上收到消息通知。

2. 手动告诉dispatch group你要开始某个任务了.完成任务之后,你也需要手动退出dispath group.

通过dispatch_group_enter(),dispatch_group_leave()两个方法可以实现进入,退出两个动作:

dispatch_group_enter(serviceGroup);
[configService startWithCompletion:^(ConfigResponse *results, NSError* error){
    // Do something with the error or results
    dispatch_group_leave(serviceGroup);
}];

每个enter都必须有相应的leave,否则,你的dispatch group永远不会结束.在你要去请求一个web service的时候,你先enter dispatch group,然后在返回的completion block中 leave.

下面举例说明dispatch_group 如何处理多个任务

-(void)fetchConfigurationWithCompletion:(void (^)(NSError* error))completion
{
    // Define errors to be processed when everything is complete.
    // One error per service; in this example we'll have two 
    __block NSError *configError = nil;
    __block NSError *preferenceError = nil;

    // Create the dispatch group
    dispatch_group_t serviceGroup = dispatch_group_create();

    // Start the first service
    dispatch_group_enter(serviceGroup);
    [self.configService startWithCompletion:^(ConfigResponse *results, NSError* error){
        // Do something with the results
        configError = error;
        dispatch_group_leave(serviceGroup);
    }];

    // Start the second service
    dispatch_group_enter(serviceGroup);
    [self.preferenceService startWithCompletion:^(PreferenceResponse *results, NSError* error){
        // Do something with the results
        preferenceError = error;
        dispatch_group_leave(serviceGroup);
    }];

    dispatch_group_notify(serviceGroup,dispatch_get_main_queue(),^{
        // Assess any errors
        NSError *overallError = nil;
        if (configError || preferenceError)
        {
            // Either make a new error or assign one of them to the overall error
            overallError = configError ?: preferenceError;
        }
        // Now call the final completion block
        completion(overallError);
    });
}

相关文章

  • 使用调度组同时处理多个任务

    假设你的应用在启动时必须向服务端进行一连串的请求.这些请求可能是获取配置信息.举个例子,当你的应用启动时可能会向服...

  • GCD group 的使用

    group 头文件中函数的解析: 调度组在项目中的使用(调度组的基本使用) 调度组:调度组是用来协调一个或多个任务...

  • GCD线程组

    使用场景 模拟多个下载任务,当所有的下载任务完成后,返回下载结束.即将每个下载任务添加到一个线程组(调度组)中,至...

  • 并发,并行 | 同步,异步 | 阻塞,非阻塞

    并发:一个处理器同时处理多个任务,在多个任务间快速切换,实现多任务同时运行的效果。称为并发 并行:多个任务同时进行...

  • 并发与并行的区别

    并发:一个处理器同时处理多个任务。 并行:多个处理器或者是多核的处理器同时处理多个不同的任务. 前者是逻辑上的同时...

  • 并行与并发的区别

    并发:一个处理器同时处理多个任务。并行:多个处理器或者是多核的处理器同时处理多个不同的任务。看下图:

  • 并发和并行的区别

    并发指的是系统能够同时处理多个任务。并行指的是系统能够同时运行多个任务。 处理未必是运行。多个任务可以先存下来,然...

  • GCD-调度组

    如果有多个执行任务,我们希望他们都执行完成后执行某一操作,可以采用调度组。 1、创建调度组: 2、创建并发任务: ...

  • Go 采用 goroutine 和 channel 实现工作池

    假设有一组任务需要异步处理且量很大,那我们需要同时开启多个 worker 以保证任务的处理速度而不会堵塞任务。其他...

  • Go 采用 goroutine 和 channel 实现工作池

    假设有一组任务需要异步处理且量很大,那我们需要同时开启多个 worker 以保证任务的处理速度而不会堵塞任务。其他...

网友评论

      本文标题:使用调度组同时处理多个任务

      本文链接:https://www.haomeiwen.com/subject/plvzyttx.html