GCD应该是比較牛逼的东西了吧,一时半会应该是操作不好。
在cocoa-china上面有两篇关于GCD的文章。GCD 深入理解(一) GCD 深入理解(二)
CSDN荣芳志博客:点击打开链接
我仅仅是读了第一篇文章,在这对里面讲的几个操作函数做一下记录:
GCD是用来优化程序支持多核处理器和多处理系统的系统,建立在线程池模式上。
原理是:将任务(函数或者block)放入队列,队列(先进先出)有两种:并行和串行;
串行队列-队列中的任务是串行的。执行完一个后接着执行下一个。可是队列与队列之间是并行的
并行队列-队列中的任务是并行的。所以结束的顺序不确定。
系统提供了四个全局并发队列 有不同的优先级background、low、default 以及 high
#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系统还提供给你一个叫做主队列的特殊队列。是一个串行队列,主要用与UI更新。
经常用法:
我们自己能够来创建队列
<span style="font-family:SimSun;font-size:12px;">dispatch_queue_t queue=dispatch_queue_create("queue1", DISPATCH_QUEUE_SERIAL);</span>
第一參数是队列的名字。第二个參数有两种DISPATCH_QUEUE_SERIAL。DISPATCH_QUEUE_CONCURRENT第一个是创建串行队列,第二个是创建并行队列。
dispatch_async
为了避免界面在处理时操作卡死,在还有一个线程中运行网络请求等操作,我们能够用dispatch_async来放入另外一个队列中。运行,主线程继续运行UI操作;
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ // 运行比較耗时的操作 dispatch_async(dispatch_get_main_queue(), ^{ // 更新界面 }); });
dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0)用来获取一个全局队列,第一个參数是上面4个全局队列中的一个。第二个參数不知道是什么意思,默认填写0即可了。
上面将块中得 操作放入获取到的全局队列中去运行,运行完毕再获取主队列来更新ui;
dispatch_group_async
能够监听一组任务是否完毕,完毕后发送一个通知。
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0); //取得一个全局并发队列 dispatch_group_t group = dispatch_group_create(); //创建一个运任务组 dispatch_group_async(group, queue, ^{ [NSThread sleepForTimeInterval:1]; //延迟一秒钟 NSLog(@"group1"); });
//向组中加入任务
dispatch_group_async(group, queue, ^{ [NSThread sleepForTimeInterval:2]; //延迟两秒钟 NSLog(@"group2"); }); <pre name="code" class="objc" style="color: rgb(120, 73, 42); font-size: 11px;">//向组中加入任务dispatch_group_async(group, queue, ^{ [NSThread sleepForTimeInterval:3]; //延迟三秒钟 NSLog(@"group3"); });
//向组中加入任务dispatch_group_notify(group, dispatch_get_main_queue(), ^{ NSLog(@"updateUi"); }); //组中全部任务完毕后发出通知dispatch_release(group); 最后取消任务组
dispatch_barrier_async
在一个队列中等到前面的任务结束后才运行,在运行此任务时保持串行(也就是运行完此任务的全部内容后其它恢复原队列的运行状态);
dispatch_queue_t queue = dispatch_queue_create("gcdtest.rongfzh.yc", DISPATCH_QUEUE_CONCURRENT); dispatch_async(queue, ^{ [NSThread sleepForTimeInterval:2]; NSLog(@"dispatch_async1"); }); dispatch_async(queue, ^{ [NSThread sleepForTimeInterval:4]; NSLog(@"dispatch_async2"); });
//以下是锁 dispatch_barrier_async(queue, ^{ NSLog(@"dispatch_barrier_async"); [NSThread sleepForTimeInterval:4]; }); dispatch_async(queue, ^{ [NSThread sleepForTimeInterval:1]; NSLog(@"dispatch_async3"); });