GCD应用及其他方法

1.GCD应用 单例模式
   
    static dispatch_once_t onceToken;
    dispatch_once(&onceToken, ^{
   
        NSLog(@"执行一次%@",[NSThread currentThread]);

});

2.延迟操作
    //1、
    NSLog(@"开始执行");
   
    //    [self performSelector:@selector(handleAction) withObject:nil afterDelay:0];
   
    //2、
   
    //DISPATCH_TIME_NOW 从现在开始
    //delayInSeconds 延迟几秒
   
    dispatch_time_t time = dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2 * NSEC_PER_SEC));
   
    //    when dispatch_time_t
   
    dispatch_after(time, dispatch_get_main_queue(), ^{
       
        NSLog(@"%@",[NSThread currentThread]);
       
    });

3.调度组

//创建调度组
    dispatch_group_t group = dispatch_group_create();
    //获取全局队列
    dispatch_queue_t queue = dispatch_get_global_queue(0, 0);
    //调度组的异步请求
    dispatch_group_async(group, queue, ^{
       
        [NSThread sleepForTimeInterval:2];
        NSLog(@"下载第一张图");
    });
    dispatch_group_async(group, queue, ^{
        [NSThread sleepForTimeInterval:3];
       
        NSLog(@"下载第二张图");
    });
    dispatch_group_async(group, queue, ^{
        [NSThread sleepForTimeInterval:1];
       
        NSLog(@"下载第三张图");
    });
    dispatch_group_async(group, queue, ^{
        [NSThread sleepForTimeInterval:5];
       
        NSLog(@"下载第四张图");
    });
    //notify通知,当所有异步请求完成时调用dispatch_group_notify
    dispatch_group_notify(group, queue, ^{
        NSLog(@"更新UI");
    });

4.调度组的第二种方式

//创建调度组
    dispatch_group_t group = dispatch_group_create();
    //获取全局队列
    dispatch_queue_t queue = dispatch_get_global_queue(0, 0);
   
    //进入队列
    dispatch_group_enter(group);
    dispatch_async(queue, ^{
       
        [NSThread sleepForTimeInterval:2];
        NSLog(@"下载第一张图");
       
        //离开队列
        dispatch_group_leave(group);
    });
   
    dispatch_group_enter(group);
    dispatch_async(queue, ^{
       
        [NSThread sleepForTimeInterval:1];
        NSLog(@"下载第er张图");
       
        dispatch_group_leave(group);
    });
   
    dispatch_group_enter(group);
    dispatch_async(queue, ^{
       
        [NSThread sleepForTimeInterval:3];
        NSLog(@"下载第san张图");
       
        dispatch_group_leave(group);
    });
   
    //等待调度队列wait相当于一个阻塞状态 等最后一个异步进程执行后,更新UI才执行
    dispatch_group_wait(group, DISPATCH_TIME_FOREVER);
   
    NSLog(@"更新UI");

5.中断操作

//dispatch_barrier_async一定是自定义队列
    //这里指定的并发队列应该是自己通过dispatch_queue_create函数创建的。如果你传的是一个串行队列或者全局并发队列,这个函数等同于dispatch_async函数。
   
    dispatch_queue_t queue = dispatch_queue_create("com.blogcn", DISPATCH_QUEUE_CONCURRENT); //dispatch_get_global_queue(0, 0);
   
    dispatch_async(queue, ^{
        [NSThread sleepForTimeInterval:1];
        NSLog(@"1");
    });
   
    dispatch_async(queue, ^{
        [NSThread sleepForTimeInterval:3];
       
        NSLog(@"2");
    });
    dispatch_async(queue, ^{
       
        [NSThread sleepForTimeInterval:2];
       
        NSLog(@"3");
    });
   
    //中断操作dispatch_barrier_async
    dispatch_barrier_async(queue, ^{
        NSLog(@"--------");
        [NSThread sleepForTimeInterval:1];
       
    });
   
    dispatch_async(queue, ^{
       
        [NSThread sleepForTimeInterval:1];
        NSLog(@"4");
    });
    dispatch_async(queue, ^{
        NSLog(@"5");
    });

6.遍历

//遍历操作
    dispatch_queue_t queue = dispatch_get_global_queue(0, 0);
    //iterations 遍历的次数
    dispatch_apply(5, queue, ^(size_t i) {
        NSLog(@"%@",@(i));
    });

时间: 2024-11-03 05:35:34

GCD应用及其他方法的相关文章

Swift中的GCD——常见的dispatch方法

  我们一般使用如下的dispatch方法: 解释: 第一句是异步执行,第二句是延迟异步执行,第三句是先后台运行,再更新UI dispatch_get_main_queue 代表应用主线程执行,可以在内部更新UI(并不会阻塞主线程) dispatch_get_global_queue 代表在系统后台运行,不一定和UI在同一线程,不能更新UI,适用于网络处理与Core Data等的处理.   修改block之外的变量 访问变量 默认情况下,在程序块中访问的外部变量是赋值(assign)过去的,即写

[New learn]GCD其他方法的使用

https://github.com/xufeng79x/GCDDemo 1.简介 在前面的两篇博文中我介绍了GCD的一般使用方法和死锁的分析调查.本博文中继续讲解GCD的其他比较常用的几个使用方法. 2.线程间的通信 线程间通信意指如何在当前线程中去通知或者去调度其他线程完成任务. 比较经典的一个用例为将耗时操作放在某个线程中(非主队列任务)然后完成后去更新控件(主队列任务). -(void)loadImage { dispatch_async(dispatch_get_global_queu

iOS学习之GCD

多线程编程 线程定义:一个CPU执行的CPU命令 列一条无分叉的路径就叫线程. 多线程:执行多个不同的CPU命令 有多条路径. 线程的使用:主线程(又叫作UI线程)主要任务是处理UI事件,显示和刷新UI,(只有主线程有直接修改UI的能力)耗时的操作放在子线程(又叫作后台线程.异步线程). 多线程容易引发的编程问题: 数据竞争:多个线程更新相同的资源会导致数据不一致. 死锁:停止等待事件的线程会导致多个线程相互持续等待. 太多线程会消耗大量内存. Thread Safe(线程安全):一段线程安全的

iOS的三种多线程技术NSThread/NSOperation/GCD

1.iOS的三种多线程技术 1.NSThread 每个NSThread对象对应一个线程,量级较轻(真正的多线程) 2.以下两点是苹果专门开发的"并发"技术,使得程序员可以不再去关心线程的具体使用问题 NSOperation/NSOperationQueue 面向对象的线程技术 GCD -- Grand Central Dispatch(派发) 是基于C语言的框架,可以充分利用多核,是苹果推荐使用的多线程技术. 以上这三种编程方式从上到下,抽象度层次是从低到高的,抽象度越高的使用越简单,

App开发流程之使用GCD

GCD即为Grand Central Dispatch的缩写,是一种主要用于异步处理任务的安全的高性能解决方案. 在此不对比其他异步处理技术,只记录GCD的使用及说明. 先记录一些必要的概念:线程,同步,异步,并行队列,串行队列 线程:程序中任务执行流的最小单元.一个应用程序,一般存在一个进程(拥有独立内存空间),而每个进程可以有多个线程,即多个任务执行流,类似于工厂车间的流水线.每个应用程序至少存在一个线程,即为主线程,作为唯一可以控制UI的线程. 同步:主要指多个任务在同一个线程上依次执行.

iOS- NSThread/NSOperation/GCD 三种多线程技术的对比及实现 -- 转

1.iOS的三种多线程技术 1.NSThread 每个NSThread对象对应一个线程,量级较轻(真正的多线程) 2.以下两点是苹果专门开发的“并发”技术,使得程序员可以不再去关心线程的具体使用问题 ØNSOperation/NSOperationQueue 面向对象的线程技术 ØGCD —— Grand Central Dispatch(派发) 是基于C语言的框架,可以充分利用多核,是苹果推荐使用的多线程技术 以上这三种编程方式从上到下,抽象度层次是从低到高的,抽象度越高的使用越简单,也是Ap

GCD 线程处理

GCD一.GCD概述二.GCD的常规使用方法三.GCD大杀器----异步下载图片并刷新UI.四.GCD+Block五一次性执行:六延迟执行七  dispatch_time_t与秒的对应关系一.GCD概述Grand宏大的 Central中央 Dispatch调度是处理多线程的,类似于NSThread,但是比NSThread强大很多架构核心是队列和执行方法,dispatch_queue_t和dispatch_async(或dispatch_sync,同步方法一般都不使用)二.GCD的常规使用方法GC

多种方法求最大公约数+求最小公倍数

本文将给出求两个数a和b的最大公约数的几种可行方法. 方法一:辗转相除法 算法分析:有两个数a和b,用辗转相除法. 不妨设a>b, 首先求a和b的余数,b赋值给a,余数赋值给b: 重复以上操作,直到余数为0: b值即为两数的最大公约数. 代码: 1 int zdgys(int a,int b) 2 { 3 int temp; 4 if( a<0 ) a=-a; 5 if( b<0 ) b=-b; 6 if( a<b ) { temp=a;a=b;b=temp; } // 让a>

iOS多线程开发之GCD(下篇)

上篇和中篇讲解了什么是GCD,如何使用GCD,这篇文章将讲解使用GCD中将遇到的死锁问题.有兴趣的朋友可以回顾<iOS多线程开发之GCD(上篇)>和<iOS多线程开发之GCD(中篇)>. 言归正传,我们首先来回顾下死锁,所谓死锁: 是指两个或两个以上的进程(线程)在执行过程中,因争夺资源(如数据源,内存等,变量不是资源)而造成的一种互相等待的现象,若无外部处理作用,它们都将无限等待下去. 死锁形成的原因: 系统资源不足 进程(线程)推进的顺序不恰当: 资源分配不当 死锁形成的条件: