GCD-semaphore(资源)-apply

本文深入探讨了如何利用dispatch_apply实现高效的并行计算,通过实例展示了如何在iOS和macOS开发中使用dispatch_queue_t进行并发任务处理,以及如何在并行计算中优化性能。

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

    NSArray *array = [[NSArray alloc]initWithObjects:@(1), @(1), @(1), @(1), @(1), nil];
    //创建一个信号源
    __block dispatch_semaphore_t sem = dispatch_semaphore_create(0);
    dispatch_queue_t queue = dispatch_queue_create("StudyBlocks", NULL);
    
    dispatch_async(queue, ^(void) {
        int sum = 0;
        for(int i = 0; i < array.count; i++)
            sum += (int)array[i];
        
        NSLog(@" >> Sum: %d", sum);
        
        //增加 semaphore 计数(可理解为资源数)
        dispatch_semaphore_signal(sem);
    });
    
    //减少 semaphore 的计数,如果资源数少于 0就等待资源有资源了再去处理
    dispatch_semaphore_wait(sem, DISPATCH_TIME_FOREVER);
    
    dispatch_release(sem);  
    dispatch_release(queue);
    

 NSArray *array = [[NSArray alloc]initWithObjects:@(1), @(1), @(1), @(1), @(1), nil];
    dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
    
    __block int sum = 0;
    //dispatch_apply 的定义如下:
    //dispatch_apply(size_t iterations, dispatch_queue_t queue, void (^block)(size_t));
    //参数 iterations 表示迭代的次数,void (^block)(size_t) 是 block 循环体。这么做与 for 循环相比有什么好处呢?答案是:并行,这里的求和是并行的,并不是按照顺序依次执行求和的。
    dispatch_apply(array.count, queue, ^(size_t i) {
        sum += (int)array[i];
    });
    
    NSLog(@" >> sum: %d", sum);
    
    dispatch_release(queue);


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值