GCD 技術(shù)是一個輕量的,底層實現(xiàn)隱藏的神奇技術(shù),我們能夠通過GCD和block輕松實現(xiàn)多線程編程,有時候,GCD相比其他系統(tǒng)提供的多線程方法更加有效,當然,有時候GCD不是最佳選擇,另一個多線程編程的技術(shù) NSOprationQueue 讓我們能夠?qū)⒑笈_線程以隊列方式依序執(zhí)行,并提供更多操作的入口,這和 GCD 的實現(xiàn)有些類似。
那這兩者直接有什么區(qū)別呢?
GCD是底層的C語言構(gòu)成的API,而NSOperationQueue及相關(guān)對象是Objc的對象。在GCD中,在隊列中執(zhí)行的是由block構(gòu)成的任務(wù),這是一個輕量級的數(shù)據(jù)結(jié)構(gòu);而Operation作為一個對象,為我們提供了更多的選擇;
在NSOperationQueue中,我們可以隨時取消已經(jīng)設(shè)定要準備執(zhí)行的任務(wù)(當然,已經(jīng)開始的任務(wù)就無法阻止了),而GCD沒法停止已經(jīng)加入queue的block(其實是有的,但需要許多復(fù)雜的代碼);
NSOperation能夠方便地設(shè)置依賴關(guān)系,我們可以讓一個Operation依賴于另一個Operation,這樣的話盡管兩個Operation處于同一個并行隊列中,但前者會直到后者執(zhí)行完畢后再執(zhí)行;
我們能將KVO應(yīng)用在NSOperation中,可以監(jiān)聽一個Operation是否完成或取消,這樣子能比GCD更加有效地掌控我們執(zhí)行的后臺任務(wù);
在NSOperation中,我們能夠設(shè)置NSOperation的priority優(yōu)先級,能夠使同一個并行隊列中的任務(wù)區(qū)分先后地執(zhí)行,而在GCD中,我們只能區(qū)分不同任務(wù)隊列的優(yōu)先級,如果要區(qū)分block任務(wù)的優(yōu)先級,也需要大量的復(fù)雜代碼;
我們能夠?qū)SOperation進行繼承,在這之上添加成員變量與成員方法,提高整個代碼的復(fù)用度,這比簡單地將block任務(wù)排入執(zhí)行隊列更有自由度,能夠在其之上添加更多自定制的功能
文/王小明if(簡書作者)
原文鏈接:http://www.itdecent.cn/p/d09e2638eb27
著作權(quán)歸作者所有,轉(zhuǎn)載請聯(lián)系作者獲得授權(quán),并標注“簡書作者”。