iOS GCD_1

這篇主要寫的是1、同異步派發(fā)(dispatch_async荠列、dispatch_sync)
2类浪、串并行隊(duì)列(DISPATCH_QUEUE_SERIAL、DISPATCH_QUEUE_CONCURRENT)

1.同異步派發(fā)(dispatch_async肌似、dispatch_sync)

  • dispatch_sync:同步派發(fā)费就。當(dāng)走到dispatch_sync 時(shí),不直接返回川队,而要直接走完block的代碼.
示例:
    char *sync = "sycnQ";
    dispatch_queue_t syncQ = dispatch_queue_create(sync, DISPATCH_QUEUE_SERIAL);
    dispatch_sync(syncQ, ^{
        NSLog(@"同步串行隊(duì)列  當(dāng)前線程------>%@", [NSThread currentThread]);
    });
    dispatch_sync(dispatch_get_global_queue(0, 0), ^{
        NSLog(@"同步并行隊(duì)列  當(dāng)前線程------>%@", [NSThread currentThread]);
    });
    //這個(gè)會造成線程阻塞力细,因?yàn)閐ispatch_sync要走完block的代碼  而主線程要等待block走完 才會走  所以同步主隊(duì)列會造成阻塞crash
    dispatch_sync(dispatch_get_main_queue(), ^
    });
打印結(jié)果:
2017-06-15 20:26:05.013 Block[9706:237965] 同步串行隊(duì)列  當(dāng)前線程------><NSThread: 0x618000075640>{number = 1, name = main}
2017-06-15 20:26:05.013 Block[9706:237965] 同步并行隊(duì)列  當(dāng)前線程------><NSThread: 0x618000075640>{number = 1, name = main}
(lldb) 

就是因?yàn)槭峭脚砂l(fā)相當(dāng)于同步執(zhí)行task,不會先執(zhí)行后面的task固额。

而同步派發(fā)所在的線程為他所在環(huán)境的線程

示例:
dispatch_async(dispatch_get_global_queue(0, 0), ^{
        
        NSLog(@"aaa當(dāng)前線程------>%@", [NSThread currentThread]);
        char *sync1 = "sycnQ1";
        dispatch_queue_t syncQ1 = dispatch_queue_create(sync1, DISPATCH_QUEUE_CONCURRENT);
        dispatch_sync(syncQ1, ^{
            
            NSLog(@"bbb當(dāng)前線程------>%@", [NSThread currentThread]);
        });
    });
打印結(jié)果:
2017-06-15 20:39:58.953 Block[9833:245664] aaa當(dāng)前線程------><NSThread: 0x6180000770c0>{number = 3, name = (null)}
2017-06-15 20:39:58.953 Block[9833:245664] bbb當(dāng)前線程------><NSThread: 0x6180000770c0>{number = 3, name = (null)}
  • 異步派發(fā)眠蚂。當(dāng)走到dispatch_async 時(shí),直接返回斗躏,繼續(xù)執(zhí)行他所在線程的其他代碼任務(wù)逝慧。
示例:
 NSLog(@"startstartstartstartstartstartstart");
    char *async = "asycnQ";
    dispatch_queue_t asyncQ = dispatch_queue_create(async, DISPATCH_QUEUE_CONCURRENT);
    dispatch_async(asyncQ, ^{
        NSLog(@"異步并行隊(duì)列  當(dāng)前線程------>%@", [NSThread currentThread]);
    });
    dispatch_async(dispatch_get_main_queue(), ^{
       
        NSLog(@"異步主隊(duì)列  當(dāng)前線程------>%@", [NSThread currentThread]);
    });
    
    dispatch_async(dispatch_get_global_queue(0, 0), ^{
        
        NSLog(@"異步全局隊(duì)列  當(dāng)前線程------>%@", [NSThread currentThread]);
    });
    char *sync = "sycnQ";
    dispatch_queue_t syncQ = dispatch_queue_create(sync, DISPATCH_QUEUE_SERIAL);
    dispatch_async(syncQ, ^{
        
        NSLog(@"異步串行隊(duì)列  當(dāng)前線程------>%@", [NSThread currentThread]);
    });
    
    NSLog(@"endendendendendendendendend");
結(jié)果為:
2017-06-15 21:05:55.498 Block[9937:254941] startstartstartstartstartstartstart
2017-06-15 21:05:55.498 Block[9937:254941] endendendendendendendendend
2017-06-15 21:05:55.498 Block[9937:255124] 異步串行隊(duì)列  當(dāng)前線程------><NSThread: 0x61000007d5c0>{number = 3, name = (null)}
2017-06-15 21:05:55.498 Block[9937:255123] 異步并行隊(duì)列  當(dāng)前線程------><NSThread: 0x6000002622c0>{number = 4, name = (null)}
2017-06-15 21:05:55.498 Block[9937:255127] 異步全局隊(duì)列  當(dāng)前線程------><NSThread: 0x61800007e7c0>{number = 5, name = (null)}
2017-06-15 21:05:55.503 Block[9937:254941] 異步主隊(duì)列  當(dāng)前線程------><NSThread: 0x60000007c740>{number = 1, name = main}

所以異步派發(fā)只在主隊(duì)列不創(chuàng)建線程,在并行(包括全局隊(duì)列)啄糙、和串行(不包括主隊(duì)列)都會創(chuàng)建線程

2.串并行隊(duì)列(DISPATCH_QUEUE_SERIAL笛臣、DISPATCH_QUEUE_CONCURRENT)

  • 串行隊(duì)列:按把任務(wù)丟進(jìn)隊(duì)列的順序,同步執(zhí)行(無論是同步派發(fā)還是異步派發(fā):只是影響在哪個(gè)線程執(zhí)行這個(gè)任務(wù))隧饼。
  • 并行隊(duì)列:針對同一個(gè)并行隊(duì)列沈堡,加入n個(gè)任務(wù),如果都是異步派發(fā)則會創(chuàng)建n個(gè)線程燕雁,同時(shí)執(zhí)行n個(gè)任務(wù)诞丽。 如果都是同步派發(fā),則會根據(jù)加入task順序執(zhí)行
示例:
char *asyncStr = "asycnQ";
    dispatch_queue_t asyncQ = dispatch_queue_create(asyncStr, DISPATCH_QUEUE_CONCURRENT);
    
    dispatch_async(asyncQ, ^{
        
        NSLog(@"異步并行隊(duì)列  線程------>%@  數(shù)字------>%d", [NSThread currentThread], 1);
    });
    
    dispatch_async(asyncQ, ^{
        
        NSLog(@"異步并行隊(duì)列  線程------>%@  數(shù)字------>%d", [NSThread currentThread], 2);
    });
    
    dispatch_sync(asyncQ, ^{
        
        NSLog(@"同步并行隊(duì)列  線程------>%@  數(shù)字------>%d", [NSThread currentThread], 3);
    });
    
    dispatch_async(asyncQ, ^{
        
        NSLog(@"異步并行隊(duì)列  線程------>%@  數(shù)字------>%d", [NSThread currentThread], 4);
    });
    
    dispatch_async(asyncQ, ^{
        
        NSLog(@"異步并行隊(duì)列  線程------>%@  數(shù)字------>%d", [NSThread currentThread], 5);
    });
結(jié)果1:
2017-06-15 22:35:34.854 Block[11257:294626] 異步并行隊(duì)列  線程------><NSThread: 0x61000006adc0>{number = 1, name = main}  數(shù)字------>3
2017-06-15 22:35:34.854 Block[11257:294667] 異步并行隊(duì)列  線程------><NSThread: 0x610000073500>{number = 3, name = (null)}  數(shù)字------>1
2017-06-15 22:35:34.854 Block[11257:294664] 異步并行隊(duì)列  線程------><NSThread: 0x6100000735c0>{number = 4, name = (null)}  數(shù)字------>2
2017-06-15 22:35:34.855 Block[11257:294665] 異步并行隊(duì)列  線程------><NSThread: 0x600000069540>{number = 5, name = (null)}  數(shù)字------>4
2017-06-15 22:35:34.855 Block[11257:294667] 異步并行隊(duì)列  線程------><NSThread: 0x610000073500>{number = 3, name = (null)}  數(shù)字------>5
結(jié)果二:
2017-06-15 22:47:14.167 Block[12836:303509] 同步并行隊(duì)列  線程------><NSThread: 0x608000079c00>{number = 1, name = main}  數(shù)字------>3
2017-06-15 22:47:14.168 Block[12836:303665] 異步并行隊(duì)列  線程------><NSThread: 0x60000007a700>{number = 4, name = (null)}  數(shù)字------>2
2017-06-15 22:47:14.167 Block[12836:303667] 異步并行隊(duì)列  線程------><NSThread: 0x61000007fb40>{number = 3, name = (null)}  數(shù)字------>1
2017-06-15 22:47:14.168 Block[12836:303694] 異步并行隊(duì)列  線程------><NSThread: 0x60000007a400>{number = 5, name = (null)}  數(shù)字------>4
2017-06-15 22:47:14.168 Block[12836:303695] 異步并行隊(duì)列  線程------><NSThread: 0x61800007ea40>{number = 6, name = (null)}  數(shù)字------>5
結(jié)果3:
2017-06-15 22:56:12.379 Block[13913:309705] 異步并行隊(duì)列  線程------><NSThread: 0x61000007e400>{number = 4, name = (null)}  數(shù)字------>2
2017-06-15 22:56:12.379 Block[13913:309596] 同步并行隊(duì)列  線程------><NSThread: 0x60800007ce40>{number = 1, name = main}  數(shù)字------>3
2017-06-15 22:56:12.379 Block[13913:309735] 異步并行隊(duì)列  線程------><NSThread: 0x61800007fa40>{number = 3, name = (null)}  數(shù)字------>1
2017-06-15 22:56:12.380 Block[13913:309705] 異步并行隊(duì)列  線程------><NSThread: 0x61000007e400>{number = 4, name = (null)}  數(shù)字------>4
2017-06-15 22:56:12.380 Block[13913:309703] 異步并行隊(duì)列  線程------><NSThread: 0x61000007e9c0>{number = 5, name = (null)}  數(shù)字------>5
結(jié)果...

每次打印都不一樣拐格,我的理解是當(dāng)執(zhí)行到3時(shí)僧免,因?yàn)?是同步派發(fā),所以會在主線程執(zhí)行任務(wù)禁荒,在執(zhí)行任務(wù)期間猬膨,3之前的1 2 都加入到了asyncQ并行隊(duì)列,也同時(shí)執(zhí)行,可能執(zhí)行完了呛伴,也可能只執(zhí)行了一個(gè),也可能都沒執(zhí)行完 所以前三個(gè)排序 是123 132 213 231 312 321 雖然4 5和1 2都是異步并行隊(duì)列執(zhí)行谒所,但是在同步執(zhí)行時(shí) 4 5 還沒加入隊(duì)列 所以 12 要比45快
GCD_1Demo傳送門

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末热康,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子劣领,更是在濱河造成了極大的恐慌姐军,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,273評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異奕锌,居然都是意外死亡著觉,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評論 3 398
  • 文/潘曉璐 我一進(jìn)店門惊暴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來饼丘,“玉大人,你說我怎么就攤上這事辽话∫薷耄” “怎么了?”我有些...
    開封第一講書人閱讀 167,709評論 0 360
  • 文/不壞的土叔 我叫張陵油啤,是天一觀的道長典徘。 經(jīng)常有香客問我,道長益咬,這世上最難降的妖魔是什么逮诲? 我笑而不...
    開封第一講書人閱讀 59,520評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮幽告,結(jié)果婚禮上梅鹦,老公的妹妹穿的比我還像新娘。我一直安慰自己评腺,他們只是感情好帘瞭,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蒿讥,像睡著了一般蝶念。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上芋绸,一...
    開封第一講書人閱讀 52,158評論 1 308
  • 那天媒殉,我揣著相機(jī)與錄音,去河邊找鬼摔敛。 笑死廷蓉,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的马昙。 我是一名探鬼主播桃犬,決...
    沈念sama閱讀 40,755評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼行楞!你這毒婦竟也來了攒暇?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,660評論 0 276
  • 序言:老撾萬榮一對情侶失蹤子房,失蹤者是張志新(化名)和其女友劉穎形用,沒想到半個(gè)月后就轧,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,203評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡田度,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評論 3 340
  • 正文 我和宋清朗相戀三年妒御,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片镇饺。...
    茶點(diǎn)故事閱讀 40,427評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡乎莉,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出兰怠,到底是詐尸還是另有隱情梦鉴,我是刑警寧澤,帶...
    沈念sama閱讀 36,122評論 5 349
  • 正文 年R本政府宣布揭保,位于F島的核電站肥橙,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏秸侣。R本人自食惡果不足惜存筏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望味榛。 院中可真熱鬧椭坚,春花似錦、人聲如沸搏色。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽频轿。三九已至垂涯,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間航邢,已是汗流浹背耕赘。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留膳殷,地道東北人操骡。 一個(gè)月前我還...
    沈念sama閱讀 48,808評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像赚窃,于是被迫代替她去往敵國和親册招。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評論 2 359

推薦閱讀更多精彩內(nèi)容

  • 在這篇文章中勒极,我將為你整理一下 iOS 開發(fā)中幾種多線程方案跨细,以及其使用方法和注意事項(xiàng)。當(dāng)然也會給出幾種多線程的案...
    張戰(zhàn)威ican閱讀 603評論 0 0
  • iOS 多線程系列 -- 基礎(chǔ)概述iOS 多線程系列 -- pthreadiOS 多線程系列 -- NSThrea...
    shannoon閱讀 853評論 0 2
  • 1. GCD簡介 什么是GCD呢河质?我們先來看看百度百科的解釋簡單了解下概念 引自百度百科:Grand Centra...
    千尋_544f閱讀 368評論 0 0
  • 緣 聚散 離又合 不曾琢磨 嘆世間冷暖 殊不知英雄落 感人世再起風(fēng)波 古今難辨情為何物 道不盡紅塵眷戀為何 雖常想...
    成利多吉閱讀 570評論 0 0