zoukankan      html  css  js  c++  java
  • GCD的简单使用方法

    版权声明:本文为博主原创文章。未经博主同意不得转载。 https://blog.csdn.net/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. });



查看全文
  • 相关阅读:
    从倒水问题到欧几里得算法扩展
    uva 10651
    STC12C5201AD AD采样+串口发送模板
    [置顶] 中国象棋程序的设计与实现–楚汉棋兵(高级版)(源码)
    【Leetcode】Same Tree
    问卷调查模块实现的过程中的历程
    差一本CSS 3的书,有兴趣的作者来写
    [置顶] 网络认证小结——你有网络身份证吗?
    音乐播放器的实现(简易版)
    空格填充器(alignBySpace)
  • 原文地址:https://www.cnblogs.com/ldxsuanfa/p/10789981.html
  • Copyright © 2011-2022 走看看