本文共 1706 字,大约阅读时间需要 5 分钟。
GCD,Grand Central Dispatch,伟大的中枢调度器。纯C语言,提供非常强大的函数。
GCD是苹果公司为多核的并行运算提出的解决方案。
GCD会自动利用更多的CPU内核(比如双核,四核)。 GCD会自动管理线程的生命周期(创建线程,调度任务,销毁线程)。 程序员只需要告诉GCD想要执行什么任务,不需要编写任何线程管理代码。任务:执行什么操作
队列:用来存放任务定制任务------确定要做的事情
将任务添加到队列中-------GCD会自动将队列的任务取出,放到对应的线程中执行。 注意:任务的取出遵循队列的FIFO原则:先进先出,后进后出queue:队列,block:任务
dispatch_sync(dispatch_queue_t queue , dispatch_block_t block);
dispatch_async(dispatch_queue_t queue , dispatch_block_t block);
同步:只能在当前线程中执行任务,不具备开启新线程的能力。
异步:可以在新的线程中执行任务,具备开启新线程的能力。可以让多个任务并发(同时)执行 (自动开启多个线程同时执行任务);
并发的功能只有在异步函数(dispatch_async)下才有效。 获得并发队列的途径: 1.dispatch_queue_create 函数创建并发队列 label:该队列的名字(标识), attr:队列的属性 DISPATCH_QUEUE_CONCURRENT 表示并发队列dispatch_queue_create(const char *label,dispatch_queue_attr_t attr);
eg:
dispatch_queue_t queue=dispatch_queue_create(“myQueue”, DISPATCH_QUEUE_CONCURRENT);
2.dispatch_get_global_queue函数获得全局的并发队列
priority:队列的优先级(分为高,默认,低,后台),flag:此参数暂时无用,用0代替即可。dispatch_get_global_queue( dispatch_queue_priority priority , unsigned long flags);
eg:
dispatch_queue_t queue=dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
让任务一个接着一个的执行(也就是说须等一个任务执行完毕后才可执行下一个任务)
1.dispatch_queue_create函数创建串行队列 label:该队列的名字(标识), attr:队列的属性DISPATCH_QUEUE_SERIAL或者NULL表示串行队列dispatch_queue_create(const char *label , dispatch_queue_attr_t attr);
eg:
dispatch_queue_t queue=dispatch_queue_create(“myqueue”, DISPATCH_QUEUE_SERIAL);
2.使用主队列
主队列是GCD自带的一种特殊的串行队列。 放置到主队列的任务,都会在主线程中执行。dispatch_get_main_queue()
eg: dispatch_queue_t queue=dispatch_get_main_queue();
同步任务和异步任务:能不能开启新的线程
并发队列和串行队列:任务的执行方式,并发(同时)执行,逐个执行。转载地址:http://dpwin.baihongyu.com/