经常使用;规避很多线程相关的复杂的逻辑
为什么会gcd?
因为pthread和nsthread要求开发人员对线程相关的知识了解深入; 手动启动线程;加锁/解锁;造成很多隐患 --》 苹果公司给出了gcd的多线程的解决方案(可选的设置)

什么是gcd?

GCD: Grand Central Dispatch: 一个多线程的解决方案
dispatch:迅速解决;
concurrent:同时发生的,并列的;serial:序列的,串行的
 
特性:
1) 基于c (宜用);
2)将原来的子线程做的任务放到队列queue(FIFO)中;以block方式执行
3) 自动的启动线程来执行队列中的任务(开发人员无需和线程直接打交道)
4) 线程数gcd会根据当前的资源自动的分配线程个数

队列类型:
串行队列:任务一个一个的按照顺序(FIFO)执行; 每次只能执行一个任务,并且必须等待前一个任务执行完毕
并行队列:同时执行多个任务;不必等待执行任务完成

执行任务方式:
同步执行:dispatch_sync队列中的任务在主线程中执行

异步执行:dispatch_async队列中的任务在子线程中执行
关键字:dispatch、queue、SERIAL、CONCURRENT
创建队列:
//1.创建一个空的串行队列(标题,队列类型[串行、并行])
DISPATCH_QUEUE_SERIAL = NULL
dispatch_queue_t queue = dispatch_queue_create("FirstSerialQueue", DISPATCH_QUEUE_SERIAL);
//1.创建一个空的并行队列
dispatch_queue_t queue = dispatch_queue_create("FirstConcurrentQueue", DISPATCH_QUEUE_CONCURRENT);
执行任务:
[NSThread currentThread]:获取当前的线程
[NSThread sleepForTimeInterval:1]:线程延时1秒
//同步执行
dispatch_sync(queue, ^{
    //线程执行的任务
    for (int i = 0; i < 10; i++) {
        [NSThread sleepForTimeInterval:1];
        NSLog(@"--------------%@", [NSThread currentThread]);
    }
});
//异步执行
dispatch_async(queue, ^{
    //线程执行的任务
});
 
将队列和执行方式组合,就有四种方式:
-(void)coders{
    for (int i = 0; i < 2; i++) {
        [NSThread sleepForTimeInterval:1];
        NSLog(@"--------------%@", [NSThread currentThread]);
    }
}
//———————————————------—不起作用哪-------------------------------------------
暂停一个队列
void dispatch_suspend ( dispatch_object_t object );
恢复一个队列
void dispatch_resume ( dispatch_object_t object );
释放一个队列
void dispatch_release ( dispatch_object_t object );
//----------------------------------------------------------------------------
//组合一:串行+同步:在主线程,按在顺序依次执行:
- (IBAction)serialSync:(id)sender {
    NSLog(@"串行队列;同步执行");
    //1.创建一个空的串行队列
    dispatch_queue_t queue = dispatch_queue_create("FirstSerialQueue", DISPATCH_QUEUE_SERIAL);
    //2.写第一个任务,并提交
    dispatch_sync(queue, ^{
        //线程执行的任务
        [self coders];
    });
    NSLog(@"打印第一个完毕");
    dispatch_sync(queue, ^{
        //线程执行的任务
        [self coders];
    });
    NSLog(@"打印第二个完毕");
}
//组合二:串行+异步:在子线程顺序执行(一个子线程)
- (IBAction)serialAsync:(id)sender {
    NSLog(@"串行队列;异步执行");
    dispatch_queue_t queue = dispatch_queue_create("SecondSerialQueue", DISPATCH_QUEUE_SERIAL);
    dispatch_async(queue, ^{
        [self coders];
    });
    NSLog(@"打印第一个完毕");
    dispatch_async(queue, ^{
        [self coders];
    });
    NSLog(@"打印第二个完毕");
}
//组合三:并行队列+同步执行=没有意义(相对于:串行+同步)
- (IBAction)concurrentSync:(id)sender {
    NSLog(@"并行队列;同步执行");
    dispatch_queue_t queue = dispatch_queue_create("FirstConcurrentQueue", DISPATCH_QUEUE_CONCURRENT);
    dispatch_sync(queue, ^{
        [self coders];
    });
    NSLog(@"打印第一个完毕");
    dispatch_sync(queue, ^{
        [self coders];
    });
    NSLog(@"打印第二个完毕");
}
//组合四:并列+异步:在子线程,一个任务对应一个子线程,并列执行
- (IBAction)concurrentAsync:(id)sender {
    NSLog(@"并行队列;异步执行");
    dispatch_queue_t queue = dispatch_queue_create("SecondConcurrentQueue", DISPATCH_QUEUE_CONCURRENT);
    dispatch_async(queue, ^{
        [self coders];
    });
    NSLog(@"打印第一个完毕");
    dispatch_async(queue, ^{
        [self coders];
    });
    NSLog(@"打印第二个完毕");
}
//----------------------------------------------------------------------------
队列:
系统创建好两个的队列:
主队列(main queue) <—> 串行队列;顺序执行任务
全局队列(global queue) <—> 并行队列

排列组合:
全局队列 +异步执行 <==> 并行队列异步执行,在子线程并行中执行
主队列 +异步执行    <==> 串行队列异步执行,在主线程顺序中执行
主队列 + 同步执行     <==> 造成死锁
 
-(void)coders{
    for (int i = 0; i <2; i++) {
        [NSThread sleepForTimeInterval:1];
        NSLog(@"-------%d-------%@", i,[NSThread currentThread]);
    }
}
- (IBAction)golbalSync:(id)sender {
    NSLog(@"全局队列 + 异步");
    //系统默认,直接获取就可以。dispatch_get_global_queue(优先级,)
    dispatch_queue_t globalQueue=dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
    //2.写第一个任务,并提交
    dispatch_async(globalQueue, ^{
        //线程执行的任务
        [self coders];
    });
    NSLog(@"打印第一个完毕");
    //3.写第二个任务,并提交
    dispatch_async(globalQueue, ^{
        //线程执行的任务
        [self coders];
    });
    NSLog(@"打印第二个完毕");
}
主队列+同步:
- (IBAction)mainSynic:(id)sender {
    NSLog(@"主队列 + 同步");
    //获取主队列,会在主线程中执行队列中的任务
    dispatch_queue_t mainQueue=dispatch_get_main_queue();
    //2.写第一个任务,并提交
    dispatch_async(mainQueue, ^{
        [self coders];
    });
    NSLog(@"打印第一个完毕");
    //3.写第二个任务,并提交
    dispatch_async(mainQueue, ^{
        [self coders];
    });
    NSLog(@"打印第二个完毕");
}
主队列(和主线程绑定):顺序执行
先执行任务一:(mainSync);
然后再执行任务二:for循环
//---------------------------------End-------------------------------------------

多线程GCD的更多相关文章

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

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

  2. iOS多线程 GCD

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

  3. 修改版: 小伙,多线程(GCD)看我就够了,骗你没好处!

    多线程(英语:multithreading),是指从软件或者硬件上实现多个线程并发执行的技术.具有多线程能力的计算机因有硬件支持而能够在同一时间执行多于一个线程,进而提升整体处理性能.具有这种能力的系 ...

  4. ios多线程-GCD基本用法

    ios中多线程有三种,NSTread, NSOperation,GCD 这篇就讲讲GCD的基本用法 平时比较多使用和看到的是: dispatch_async(dispatch_get_global_q ...

  5. iOS 多线程GCD简介

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

  6. 多线程GCD的基本使用以及注意点

    GCD的使用  一:队列    1.串行队列:添加到队列中的任务是一个一个执行的    2.并行(发)队列:添加到队列中的任务是多个同时执行的(一个队列中的多个任务可以同时执行)    3.主队列:里 ...

  7. IOS开发之多线程 -- GCD的方方面面

    前言:这篇GCD的博文是本人阅读了很多海内外大神的关于GCD的文章,以及结合之前自己对GCD的粗浅的认识,然后取其精华,去其槽粕,综合起来的笔记,而且是尽可能的以通熟易懂的并且是正确的理论论述方式呈现 ...

  8. 刀哥多线程GCD核心概念gcd

    GCD GCD 核心概念 将任务添加到队列,并且指定执行任务的函数 任务使用 block 封装 任务的 block 没有参数也没有返回值 执行任务的函数 异步 dispatch_async 不用等待当 ...

  9. ios开发多线程--GCD

    引言 虽然GCD使用很广,而且在面试时也经常问与GCD相关的问题,但是我相信深入理解关于GCD知识的人肯定不多,大部分都是人云亦云,只是使用过GCD完成一些很简单的功能.当然,使用GCD完成一些简单的 ...

随机推荐

  1. [面试题] BloomFilter 无序40亿不重复 uint 整数, 给予任意的数,求是否在这40亿之中 + 无序数组中找2个相同的值

    一道百度面试题(待解中) 具体:给40亿个不重复的unsigned int的整数,没排过序的,然后再给几个数,如何快速判断这几个数是否在那40亿个数当中? 分析下,首先应该是空间复杂度(40亿uint ...

  2. (转载)memcpy的几个实现版本

    (转载)http://blog.sina.com.cn/s/blog_4d3a41f40100cvza.html 实现void *memcpy(void *to, const void *from, ...

  3. 常用ping服务列表

    以下是收集的ping服务器. ping是基于XML_RPC标准协议的更新通告服务,是用于blog在内容更新时通知博客搜索引擎及时进行抓取.更新的方式.博客搜索引擎在成功接受到ping以后,会立刻进行抓 ...

  4. 编程精粹:编写高质量的C语言代码———笔记一

    第一章 假想的编译程序 要记得对空语句进行处理,最好使用NULL使其明显可见 char * strcpy(char* pchTo, char* pchFrom) { char* pchStart = ...

  5. Appium自动化测试环境的搭建及脚本执行

    之前搭建了robotium的环境,并使用了一下,因为需要兼顾到ios的测试,所以这次又搭建了appium的环境.关于Appium的介绍网上有很多了,也可以去它的官网学习,这里就不在赘述了. 具体搭建步 ...

  6. 解读四大移动web应用开发框架真相

    [51CTO译文]近来关于新的移动网页框架及移动平台存在不少争论.平心而论,这些工具在条款内容方面的混乱与模糊也是造成大家误解的原因之一.我希望通过几条简短的评述来尽量清理这种认识层面上的混乱状态. ...

  7. LeetCode题解——ZigZag Conversion

    题目: 把一个字符串按照Z型排列后打印出来,例如 "PAYPALISHIRING" 重新排列后为3行,即 P A H N A P L S I I G Y I R 那么输出为&quo ...

  8. 标准的TCP/IP工业以太网-EtherNet/IP

    标准的TCP/IP工业以太网-EtherNet/IP                            徐智穹以太网具有传输速度高.兼容性好.应用广泛等方面的优势,支持几乎所有流行的网络协议,其中 ...

  9. Tcp服务端判断客户端是否断开连接

    今天搞tcp链接弄了一天,前面创建socket,绑定,监听等主要分清自己的参数,udp还是tcp的.好不容易调通了,然后就是一个需求,当客户端主动断开连接时,服务端也要断开连接,这样一下次客户端请求链 ...

  10. Bzoj 4403: 序列统计 Lucas定理,组合数学,数论

    4403: 序列统计 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 328  Solved: 162[Submit][Status][Discuss] ...