一、
GCD
的优势
1. GCD 是苹果公司为多核的并行运算提出的解决方案。
1. GCD 是苹果公司为多核的并行运算提出的解决方案。
2.GCD会自动利用更多的CPU内核(比如双核、四核)。
3.GCD会自动管理线程的生命周期(创建线程、调度任务、销毁线程)。
二、GCD有两个核心概念
1.任务
2.队列
三、使用CGD的步骤
1.定制任务
2.将任务添加到队列中,CGD会自动将队列中的任务取出,放到对应的线程中执行。任务的取出遵循队列的FIFD原则,先进先出,后进后出。
四、同步和异步的区别
1.同步只能在当前线程中执行任务,不具备开启新线程的能力
2.异步可以在新的线程中执行任务,具备开启新线程的能力。
五、CGD的队列可以分为2大类
1.并发队列
(1).可以让多个任务并发执行(自动开启多个线程同时执行任务)。
(2).并发的功能只有在异步(dispatch_async)函数下才有效。
2.串行队列
让任务一个接着一个地执行(一个任务执行完毕后,再执行下一个任务)。
六、同步、异步、并发、串行的关系
1.同步和异步主要影响能不能开启新的线程。
2.同步,在当前线程中执行任务,不具备开启新线程的能力。
3.异步,在新的线程中执行任务,具备开启新线程的能力。
4.并发和串行主要影响:任何的执行方式。
5.并发,多个任务并发执行。
6.串行,一个任务执行完毕后,在执行下一个任务。
七、
GCD中有2个用来执行任务的函数
1.
用同步的方式执行任务
dispatch_sync(dispatch_queue_t queue, dispatch_block_t block);
其中queue是队列,block是任务。
dispatch_sync(dispatch_queue_t queue, dispatch_block_t block);
其中queue是队列,block是任务。
2. 用异步的方式执行任务
dispatch_async(dispatch_queue_t queue, dispatch_block_t block);
八、全局的并发队列
GCD
默认已经提供了全局的并发队列,供整个应用使用,不需要手动创建。
使用 dispatch_get_global_queue 函数获得全局的并发队列
dispatch_queue_t dispatch_get_global_queue(
dispatch_queue_priority_t priority, // 队列的优先级
unsigned long flags); // 此参数暂时无用,用 0 即可
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0 ); // 获得全局并发队列
九、全局并发队列的优先级
#define DISPATCH_QUEUE_PRIORITY_HIGH 2 // 高
#define DISPATCH_QUEUE_PRIORITY_DEFAULT 0 // 默认(中)
#define DISPATCH_QUEUE_PRIORITY_LOW (- 2 ) // 低
#define DISPATCH_QUEUE_PRIORITY_BACKGROUND INT16_MIN // 后台
十、GCD
中获得串行有
2
种途径
1. 使用 dispatch_queue_create 函数创建串行队列
dispatch_queue_t
dispatch_queue_create( const char *label, // 队列名称
dispatch_queue_attr_t attr); // 队列属性,一般用 NULL 即可
dispatch_queue_t queue = dispatch_queue_create ( "cn.itcast.queue" , NULL ); // 创建
1. 使用 dispatch_queue_create 函数创建串行队列
dispatch_queue_t
dispatch_queue_create( const char *label, // 队列名称
dispatch_queue_attr_t attr); // 队列属性,一般用 NULL 即可
dispatch_queue_t queue = dispatch_queue_create ( "cn.itcast.queue" , NULL ); // 创建
注意:
手动创建串行队列,非ARC需要释放手动创建的队列
dispatch_release(queue);
2. 使用主队列(跟主线程相关联的队列)
主队列是 GCD 自带的一种特殊的串行队列
放在主队列中的任务,都会放到主线程中执行
使用 dispatch_get_main_queue() 获得主队列
dispatch_queue_t queue = dispatch_get_main_queue ();
dispatch_release(queue);
2. 使用主队列(跟主线程相关联的队列)
主队列是 GCD 自带的一种特殊的串行队列
放在主队列中的任务,都会放到主线程中执行
使用 dispatch_get_main_queue() 获得主队列
dispatch_queue_t queue = dispatch_get_main_queue ();
注意:使用sync函数往主队列中添加任务,会卡主当前的串行队列
十一、补充
凡是函数名种带有
create\copy\new\retain
等字眼
,
都应该在不需要使用这个数据的时候进行
release
GCD 的数据类型在 ARC 环境下不需要再做 release
CF(Core Foundation) 的数据类型在 ARC 环境下还是需要再做 release
GCD 的数据类型在 ARC 环境下不需要再做 release
CF(Core Foundation) 的数据类型在 ARC 环境下还是需要再做 release
注意:
NSString *str1 = @"NSString"; // Founation
CFStringRef str2 = (__bridge CFStringRef)(str1);// Core Foundation
CFStringRef str2 = (__bridge CFStringRef)(str1);// Core Foundation
__bridge CFStringRef的意思是桥接,会自动将OC字符串转化成Core Foundation字符串.
CFArrayRef array = CFArrayCreate(NULL, NULL, 10, NULL);
CFRelease(array);
CFRelease(array);
Core Foundation中手动创建的数据类型,需要手动释放内存。其中CFRelease();会释放所有Core Foundation框架手动创建类型的内存。