• 延迟执行任务函数dispatch_after(.....)

      -(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
    NSLog(@"start");
    //dispatch_after 是异步执行的
    //队列只决定在哪个线程中执行任务 并不能决定执行时间
    /**
    * 第一个参数: 在哪个时间点执行
    * dispatch_time(从哪个时间点开始,经历多少纳秒)
    * 第二个参数: 在哪个队列中执行block任务
    * 第三个参数: block任务
    */
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
    NSLog(@"%@",[NSThread currentThread]);
    });
    NSLog(@"end");
    }
原文链接:http://www.jianshu.com/p/4e46b4e0eb65

  • 一次性执行dispatch_once(...)

     -(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
    //一次性执行的机制,能保证在程序启动后只会执行一次,并且是线程安全的,在主线程中执行
    //一般使用dispatch_once来做一次性执行,效率高, 在单例模式中使用.
    //可以利用互斥锁在实现此功能,但不建议使用,因为效率非常低!!!!
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
    NSLog(@"");
    });
    }
  • 栅栏函数dispatch_barrier_async/dispatch_barrier_sync

    -(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
    
     dispatch_queue_t queue = dispatch_queue_create("yuxuan", DISPATCH_QUEUE_CONCURRENT);
    
     dispatch_async(queue, ^{
    NSLog(@"任务1");
    }); dispatch_async(queue, ^{
    NSLog(@"任务2");
    }); //栅栏函数(同步函数就没必要控制顺序了,因为它是有序的)
    //dispatch_barrier_async 是异步函数不会阻塞线程
    //dispatch_barrier_sync 是同步函数 会阻塞线程
    //如果所有任务都在同一个并行队列中,并且这个并行队列不是系统自带全局并行队列
    //哪么在barrier之前添加的方法会先被执行,只有等barrier之前的任务执行完毕后才会执行barrier任务
    //只有barrier任务执行完毕后,才会执行后添加的任务
    dispatch_barrier_async(queue, ^{
    NSLog(@"我是个可爱的路障");
    }); dispatch_async(queue, ^{
    NSLog(@"任务3");
    }); dispatch_async(queue, ^{
    NSLog(@"任务4");
    }); NSLog(@"end");
    }
  • 队列组的使用dispatch_group_t

    • 方式一:

      -(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
      
      //创建一个队列组
      dispatch_group_t group = dispatch_group_create(); //创建两个不同的队列来测试
      dispatch_queue_t queue1 = dispatch_get_global_queue(0, 0); dispatch_queue_t queue2 = dispatch_queue_create("yuxuan", DISPATCH_QUEUE_CONCURRENT); //dispatch_group_async 异步函数
      //系统会先把任务放入队列中,然后把队列放入组中
      //从组中把队列取出来,在从队列里取任务执行
      dispatch_group_async(group, queue1, ^{
      [NSThread sleepForTimeInterval:1.0];
      NSLog(@"download 1");
      }); dispatch_group_async(group, queue2, ^{
      [NSThread sleepForTimeInterval:1.0];
      NSLog(@"download 2");
      });
      //给group添加一个通知,异步函数
      //当group队列中所有任务执行完毕,就会通知group执行block
      /*
      * 第一个参数: 为那个队列组添加通知
      * 第二个参数: 决定block在什么线程中执行
      * 第三个参数: block 代码块
      */
      dispatch_group_notify(group, dispatch_queue_create("yuxuan1",DISPATCH_QUEUE_CONCURRENT), ^{
      NSLog(@"OK");
      });
      NSLog(@"end");
      }
    • 方式二:

      -(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
      /*
      dispatch_group_async底层实现:
      void dispatch_group_async(dispatch_group_t group, dispatch_queue_t queue, dispatch_block_t block)
      {
      dispatch_retain(group);
      dispatch_group_enter(group);
      dispatch_async(queue, ^{
      block();
      dispatch_group_leave(group);
      dispatch_release(group);
      });
      }
      */
      dispatch_queue_t queue = dispatch_get_global_queue(0, 0); //创建一个队列组
      dispatch_group_t group = dispatch_group_create(); //通知队列组进入队列组
      dispatch_group_enter(group); dispatch_async(queue, ^{
      NSLog(@"111");
      //任务执行完毕
      //通知队列组离开队列组
      dispatch_group_leave(group);
      }); //通知队列组进入队列组
      dispatch_group_enter(group); dispatch_async(queue, ^{
      NSLog(@"222");
      //任务执行完毕
      //通知队列组离开队列组
      dispatch_group_leave(group);
      }); //等待所有任务执行完毕,一直等待.会阻塞线程
      dispatch_group_wait(group, DISPATCH_TIME_FOREVER); // dispatch_group_notify(group, queue, ^{
      // NSLog(@"over");
      // });
      }
  • GCD定时器

    -(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
    //创建一个队列,创建GCD定时器时使用
    dispatch_queue_t queue = dispatch_queue_create("yuxuan", DISPATCH_QUEUE_SERIAL);
    //创建一个GCD定时器(触发器)
    //第四个参数:传入一个队列,决定了定时器回调任务执行方式.
    dispatch_source_t timer = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0, queue);
    //dispatch_source_t其实本质是一个类,由于是局部变量,方法执行完,就会被释放.
    self.timer = timer;
    //设置定时器
    /*
    第一个参数:给那个定时器设置
    第二个参数:什么时候启动
    第三个参数:间隔多久执行一次
    第四个参数:设置精准度:0 代表最高精准(尽量让定时器精准), 大于0的的话代表是在多少秒内接受.
    第四个参数存在意义:主要是为了提高程序性能, 设置越大,能减轻CPU的压力
    注意:GCD定时器传入的时间都是纳秒
    */
    dispatch_source_set_timer(timer, DISPATCH_TIME_NOW, 1.0 * NSEC_PER_SEC, 0.0 * NSEC_PER_SEC);
    //第一个参数:给那个定时器设置
    //第二个参数:设置定时器回调block
    //异步执行的,具有创建新线程的能力
    //具体是否创建线程,创建几条线程是由定时任务创建时,传入的queue决定的
    dispatch_source_set_event_handler(timer, ^{
    NSLog(@"%@",[NSThread currentThread]);
    });
    //启动定时器
    dispatch_resume(timer);
    }

iOS多线程-GCD之常用函数的更多相关文章

  1. iOS多线程 GCD

    iOS多线程 GCD Grand Central Dispatch (GCD)是Apple开发的一个多核编程的解决方法. dispatch queue分成以下三种: 1)运行在主线程的Main que ...

  2. iOS 多线程 GCD part3:API

    https://www.jianshu.com/p/072111f5889d 2017.03.05 22:54* 字数 1667 阅读 88评论 0喜欢 1 0. 预备知识 GCD对时间的描述有些新奇 ...

  3. iOS 多线程GCD的基本使用

    <iOS多线程简介>中提到:GCD中有2个核心概念:1.任务(执行什么操作)2.队列(用来存放任务) 那么多线程GCD的基本使用有哪些呢? 可以分以下多种情况: 1.异步函数 + 并发队列 ...

  4. iOS 多线程GCD简介

    一.简介 1.1 GCD (Grand Central Dispatch )是Apple开发的一个多核编程的解决方法. Grand 含义是“伟大的.宏大的”,Central含义“中央的”,Dispat ...

  5. iOS多线程GCD的使用

    1. GCD 简介 Grand Central Dispatch(GCD)是异步执行任务的技术之一.一般将应用程序中记述的线程管理用的代码在系统级中实现.开发者只需要定义想执行的任务并追加到适当的Di ...

  6. iOS - 多线程——GCD

    什么是GCD           Grand Central Dispatch(强大的调度器),是一个C语言API:           作用:多核并行运算的解决方案:  GCD中有2个核心概念    ...

  7. ios多线程开发的常用三种方式

    1.NSThread 2.NSOperationQueue 3.GCD NSThread: 创建方式主要有两种: [NSThread detachNewThreadSelector:@selector ...

  8. iOS多线程——GCD与NSOperation总结

    很长时间以来,我个人(可能还有很多同学),对多线程编程都存在一些误解.一个很明显的表现是,很多人有这样的看法: 新开一个线程,能提高速度,避免阻塞主线程 毕竟多线程嘛,几个线程一起跑任务,速度快,还不 ...

  9. iOS多线程GCD详解

    在这之前,一直有个疑问就是:gcd的系统管理多线程的概念,如果你看到gcd管理多线程你肯定也有这样的疑问,就是:并发队列怎么回事,即是队列(先进先出)怎么会并发,本人郁闷了好久,才发现其实cgd管理多 ...

随机推荐

  1. 无法解析指定对象的 TargetProperty (UIElement.RenderTransform).(TransformGroup.Children)[0].(ScaleTransform.ScaleX)“的异常解决

    最近在写动画的时候做一个倒计时的效果,就是数字从大到小的一个动画,但是当我设置要new PropertyPath("XXXXXXX")的时候却报了标题的异常,各种报错.百度了好久也 ...

  2. 堆排序(python实现)

    堆排序是利用最大最或最小堆,废话不多说: 先给出几个概念: 二叉树:二叉树是每个节点最多有两个子树的树结构.通常子树被称作“左子树”(left subtree)和“右子树” 完全二叉树:除最后一层外, ...

  3. CSS3 基于关系的选择器

    常见的基于关系的选择器 选择器 选择的元素 A E 元素A的任一后代元素E (后代节点指A的子节点,子节点的子节点,以此类推) A > E 元素A的任一子元素E(也就是直系后代) E:first ...

  4. [No00009C]Visual Studio在 解决方案资源管理器 里同步定位打开的文件

    标题的意思就是在使用VS的时候,需要我们打开编辑的文件跟解决方案的资源管理器同步显示,这样方便定位到我们在修改哪个文件. 设置如下: 工具——选项——项目和解决方案——在解决方案资源管理器中跟踪活动项 ...

  5. MikroTik RB750r2 操作记录

    1. 客户端的下载 http://www.mikrotik.com/download  下载 winbox 2. Reset重置密码的正确姿势 http://wiki.mikrotik.com/ind ...

  6. 一个简单oop的changeTab

    好多地方都会用到这样一个效果“点击tab切换内容页”,根据自己的想法实现了一下,写了个简单的插件.以前写代码都是标准的函数式编程,现在觉得面向对象编程看起来比较爽,并且更容易维护,于是就用oop的思想 ...

  7. 常用 Git 命令清单

    我每天使用 Git ,但是很多命令记不住. 一般来说,日常使用只要记住下图6个命令,就可以了.但是熟练使用,恐怕要记住60-100个命令. 下面是我整理的常用 Git 命令清单.几个专用名词的译名如下 ...

  8. Error 1606 Could Not Access Network Location %SystemDrive%/inetpub/wwwroot/ 的错误解决方法

    在卸载或者重安装Infragistics NetAdvantage时候提示如标题的错误 win7下 1.打开注册表 Regedit 2.找到HKEY_LOCAL_MACHINE/SOFTWARE/Mi ...

  9. 递推 hdu 1396

    给你边长为n的等边三角形 算有几个三角形 z[1]=1; 第N层 z[n] 1   n-1层 z[n-1] 2   2*n-1 个小的 3   新产生的 正的>1的三角形 n*(n-1)/2; ...

  10. 使用bat(批处理文件类型)两步更改笔记本IP

    一.背景 在南农工的第三年里,学校终于给教学区覆盖了无线网NJAUPK,这解决了我在汇贤楼教室上自习没网写web的尴尬处境!经常在9栋和汇贤楼教学区之间来回,遇见了一个大问题:宿舍里无线需要更改IPV ...