GCD的简单使用方法

本文深入解析GCD(Grand Central Dispatch)中并行与串行队列的使用方法,包括如何创建并行队列、串行队列,以及如何使用队列进行任务调度。详细介绍了四种不同优先级的全局队列,如何利用dispatch_group进行任务组管理,以及如何确保代码在主线程中执行。此外,还探讨了如何使用dispatch_apply替代for循环以提高并行处理效率。
版权声明:本文为博主原创文章。未经博主同意不得转载。 https://blog.youkuaiyun.com/like7xiaoben/article/details/25629365
/*
     创建一个队列用来运行任务。TA属于系统提前定义的并行队列即全局队列,眼下系统提前定义了四个不同运行优先级的全局队列,我们能够通过dispatch_get_global_queue来获取它们
     四种优先级
     DISPATCH_QUEUE_PRIORITY_HIGH
     DISPATCH_QUEUE_PRIORITY_DEFAULT
     DISPATCH_QUEUE_PRIORITY_LOW
     DISPATCH_QUEUE_PRIORITY_BACKGROUND
     
     不得已情况下可用dispatch_queue_create("newQueue", NULL); 创建,注意假设用此种方法创建需调用dispatch_release(queue)来释放此队列
     */
    dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
    //运行队列
    dispatch_async(queue, ^{
        //此队列运行的代码
    });
    //假设有多个队列运行,能够创建一个队列数组
    dispatch_group_t queueGroup = dispatch_group_create();
    //把一个个队列加入到数组中,先把任务加入到队列。然后再把队列和数组关联
    dispatch_group_async(queueGroup, queue, ^{
        //要运行的任务
    });
    
    /*
     dispatch_group_notify
        指定一个额外的程序块,该程序块将在组中的全部程序块即将运行完毕时运行
     dispatch_get_main_queue()
        系统默认的一个串行队列与主线程功能同样。实际上。提交至main queue的任务会在主线程中运行,main queue能够调用dispatch_get_main_queue()来获得。由于main queue是与主线程相关的
     */
    dispatch_group_notify(queueGroup, dispatch_get_main_queue(), ^{
        //运行代码
    });
    //获取运行的队列
    dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
        //运行完后运行此处代码
    });
    //dispatch_barrier_async是在前面的任务运行结束后它才运行。并且它后面的任务等它运行完毕之后才会运行
    dispatch_barrier_async(queue, ^{
        //运行代码
    });
    
    //dispatch_apply 运行某个代码片段N次
    dispatch_apply(5, queue, ^(size_t index) {
        // 运行5次
    });
    
    /*
     回归主线程
     __block 能够在block内部改动的变量。用此修饰符标识
     */
    __block NSString *updateStr = @"1";
    dispatch_async(dispatch_get_main_queue(), ^{
        NSLog(@"回归主线程");
        updateStr = @"2";
    });
    
    //取代for循环 假设for循环中处理的任务是可并发的(并发,在操作系统中。是指一个时间段中有几个程序都处于已启动运行到运行完毕之间,且这几个程序都是在同一个处理机上运行,但任一个时刻点上仅仅有一个程序在处理机上运行)。显然放到一个线程中处理是非常慢的。GCD提供两个函数dispatch_apply和dispatch_apply_f,dispatch_apply是用于Block的,而dispatch_apply_f能够用于c函数,它们能够替代可并发的for循环,来并行的运行而提高运行效率
    int count = 10;
    for (int i = 0; i < count; i++) {
        //do a lot of work here.
    }
    dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
    dispatch_apply(count, queue, ^(size_t i) {
        //do a lot of work here.
    });


转载于:https://www.cnblogs.com/ldxsuanfa/p/10048134.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值