GCD-group、notify、wait

本文通过两个实例深入解析了GCD (Grand Central Dispatch) 中dispatch_group_notify和dispatch_group_wait的功能与用法。第一个例子展示了如何使用dispatch_group_notify实现任务完成后的回调通知。第二个例子则演示了dispatch_group_wait如何让后续代码等待所有分组任务完成后继续执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1 dispatch_group_notify,dispatch_group_async执行完后再执行notify;

2 dispatch_group_wait后代码等group执行完,再执行;

 

例1 dispatch_group_notify


- (void)groupAsyncSummit_notify{
    dispatch_group_t group = dispatch_group_create();

    dispatch_group_async(group, _mainQueue, ^{
        [self doSometing:@"1"];
        });
    dispatch_group_async(group, _mainQueue, ^{
        [self doSometing:@"2"];
    });
   
    dispatch_group_notify(group, _globalQueue, ^{
        [self doSometing:@"notify"];
    });
    
    dispatch_group_async(group, _globalQueue, ^{
        [self doSometing:@"3"];
        [self doSometing:@"3-1"];

    });
    [self doSometing:@"4"];
}

输出:43并发,再3-1、1并发,再执行2,最后执行notify;

说明:

dispatch_group_async搭_globalQueue,异步并发执行;

dispatch_group_async搭 _mainQueue,异步串行,加在_mainQueue队列的最后;

 

例2 dispatch_group_wait,


- (void)groupAsyncSummit_wait{
    dispatch_group_t group = dispatch_group_create();
    
    dispatch_group_async(group, _globalQueue, ^{
        [self doSometing:@"1"];
    });
    dispatch_group_async(group, _globalQueue, ^{
        [self doSometing:@"2"];
    });
    dispatch_group_async(group, _globalQueue, ^{
        [self doSometing:@"3"];
    });
   
    dispatch_group_wait(group, DISPATCH_TIME_FOREVER);
    
    [self doSometing:@"4"];
}

输出:1 2 3 并发执行 , 4最后执行

说明:dispatch_group_wait后代码等group执行完,再执行;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值