1.GCD簡單介紹程序員
GCD全稱爲"Grand Central Dispath" 純C語言,提供了很是強大的函數併發
2.GCD的好處異步
GCD是蘋果爲多核的並行運算提出的解決方案async
GCD會自動利用更多的CPU內核函數
GCD會自動管理線程的生命週期(建立線程,調度任務,銷燬線程)spa
運用GCD,程序員不須要編寫任何線程管理代碼線程
GCD的函數大多數是以dispatch開頭生命週期
3.任務和隊列隊列
任務:執行什麼操做get
隊列:用來存聽任務
GCD使用的步驟:定製任務、肯定想作的事
將任務添加到隊列中,GCD會自動將隊列中的任務取出,放到對應的線程中執行。任務的取出遵循隊列的FIFO原則:先進先出
4.執行任務
1.GCD中有2個用來執行任務的函數
把右邊的函數(任務)提交給左邊的參數(隊列)進行執行
(1)用同步的方式執行任務dispatch_sync(dispatch_queue_t queue,dispatch_block_t block);
參數說明:queue 隊列;block 任務
(2)用異步的方式執行任務 dispatch_async(dispatch_queue_t queue,dispatch_block_t block);
2.同步和異步的區別
同步:在當前線程中執行
異步:在另外一條線程中執行
3.隊列
併發隊列:可讓多個任務同時執行,只能在異步函數下才有效
串行隊列:讓任務一個接着一個的執行(一個任務執行完畢後,再執行下一個任務)
5.串行隊列
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(@"guozhenwei",NULL);建立
(2)使用主隊列(和主線程相關聯的隊列)
主隊列是GCD自帶的一種特殊的串行隊列,放在主隊列中的任務,都會放倒主線程中執行
使用dispatch_get_main_queue()得到主隊列
示例:
dispatch_queue_t queue = dispatch_get_main_queue();
6.併發隊列
GCD默認已經提供了全局的併發隊列,供整個應用使用,不須要手動建立
使用dispatch_get_global_queue函數得到全局的併發隊列
dispatch_queue_t dispatch_get_global_queue(dispatch_queue_priority_t priority,unsigned long flags);//此參數暫時無用,用0便可
示例:
這個參數是留給之後用的,暫時用不上,傳0;
第一個參數爲優先級,這裏爲默認的。獲取一個全局的默認優先級的併發隊列
dispatch_queue_t queue = dispatch_get_global_queue(DISPATHCH_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 // 後臺
7.各類隊列之間的關係:
8.示例代碼:
(1)用異步函數往併發隊列中添加任務 ,
(2)使用異步函數的串行隊列 只會開啓一個線程
33)小結
說明:同步函數不具有開啓線程的能力,不管是什麼隊列都不會開啓線程;異步函數具有開啓線程的能力,開啓幾條線程由隊列決定(串行隊列只會開啓一條新的線程,併發隊列會開啓多條線程)。
同步函數
(1)併發隊列:不會開線程
(2)串行隊列:不會開線程
異步函數
(1)併發隊列:能開啓N條線程
(2)串行隊列:開啓1條線程
補充:
凡是函數中,各類函數名中帶有create\copy\new\retain等字眼,都須要在不須要使用這個數據的時候進行release。
GCD的數據類型在ARC的環境下不須要再作release。
CF(core Foundation)的數據類型在ARC環境下仍是須要作release。
異步函數具有開線程的能力,但不必定會開線程
//緣由 dispatch_sync 是同步線程執行代碼 要阻塞當前線程,若是當前線程是主線程,首先被阻塞,而後執行2輸出,問題是代碼的參數是dispatch_get_main_queue() 它會獲取主線程而後在主線程執行 2輸出 主線程原本就被阻塞 因此形成了互鎖。
NSLog(@"1");
dispatch_sync(dispatch_get_main_queue() , ^{
NSLog(@"2");
});
NSLog(@"3");