- Grand Central Dispatch。它是苹果为多核的并行运算提出的解决方案,所以会自动合理地利用更多的CPU内核(比如双核、四核),最重要的是它会自动管理线程的生命周期(创建线程、调度任务、销毁线程),完全不需要我们管理,我们只需要告诉干什么就行。同时它使用的也是 c语言,不过由于使用了 Block(Swift里叫做闭包),使得使用起来更加方便,而且灵活。所以基本上大家都使用 GCD 这套方案,老少咸宜,实在是居家旅行、杀人灭口,必备良药。
同步:必须等待当前语句执行完毕,才会执行下一条语句
异步:不用等待当前语句执行完毕,就可以执行下一条语句
- GCD与 NSThread 的对比
所有的代码写在一起的,让代码更加简单,易于阅读和维护NSThread 通过 @selector 指定要执行的方法,代码分散。 GCD 通过 block 指定要执行的代码,代码集中。使用 GCD 不需要管理线程的创建/销毁/复用的过程!程序员不用关心线程的生命周期。如果要开多个线程 NSThread 必须实例化多个线程对象。NSThread 靠 NSObject 的分类方法实现的线程间通讯,GCD 靠 block。
- 串行队列
以先进先出的方式,顺序调度队列中的任务执行。无论队列中所指定的执行任务函数是同步还是异步,都会等待前一个任务执行完成后,再调度后面的任务。
dispatch_queue_tqueue = dispatch_queue_create("itcast.cn", DISPATCH_QUEUE_SERIAL);
dispatch_queue_tqueue =dispatch_queue_create("itcast.cn", NULL);
- 并发队列
以先进先出的方式,并发调度队列中的任务执行。
如果当前调度的任务是同步执行的,会等待任务执行完成后,再调度后续的任务。 如果当前调度的任务是异步执行的,同时底层线程池有可用的线程资源,会再新的线程调度后续任务的执行。
dispatch_queue_t queue = dispatch_queue_create("cn.itcast", DISPATCH_QUEUE_CONCURRENT);
- 主队列
1.专门用来在主线程上调度任务的队列。
不会开启线程。
以先进先出的方式,在主线程空闲时才会调度队列中的任务在主线程执行。
如果当前主线程正在有任务执行,那么无论主队列中当前被添加了什么任务,都不会被调度。
2.主队列的获取
主队列是负责在主线程调度任务的
会随着程序启动一起创建
主队列只需要获取不用创建
dispatch_queue_t queue = dispatch_get_main_queue();
-
总结