IOSGCD全解-創(chuàng)新互聯(lián)

介紹:
Grand Central Dispatch 簡(jiǎn)稱(GCD)是蘋果公司開發(fā)的技術(shù),以優(yōu)化的應(yīng)用程序支持多核心處理器和其他的對(duì)稱多處理系統(tǒng)的系統(tǒng)。這建立在任務(wù)并行執(zhí)行的線程池模式的基礎(chǔ)上的。它首次發(fā)布在Mac OS X 10.6 ,iOS 4及以上也可用。
 設(shè)計(jì):
GCD的工作原理是:讓程序平行排隊(duì)的特定任務(wù),根據(jù)可用的處理資源,安排他們?cè)谌魏慰捎玫奶幚砥骱诵纳蠄?zhí)行任務(wù)。
 一個(gè)任務(wù)可以是一個(gè)函數(shù)(function)或者是一個(gè)block。 GCD的底層依然是用線程實(shí)現(xiàn),不過這樣可以讓程序員不用關(guān)注實(shí)現(xiàn)的細(xì)節(jié)。
GCD中的FIFO隊(duì)列稱為dispatch queue,它可以保證先進(jìn)來的任務(wù)先得到執(zhí)行
dispatch queue分為下面三種:
Serial
又稱為private dispatch queues,同時(shí)只執(zhí)行一個(gè)任務(wù)。Serial queue通常用于同步訪問特定的資源或數(shù)據(jù)。當(dāng)你創(chuàng)建多個(gè)Serial queue時(shí),雖然它們各自是同步執(zhí)行的,但Serial queue與Serial queue之間是并發(fā)執(zhí)行的。
Concurrent
又稱為global dispatch queue,可以并發(fā)地執(zhí)行多個(gè)任務(wù),但是執(zhí)行完成的順序是隨機(jī)的。
Main dispatch queue
它是全局可用的serial queue,它是在應(yīng)用程序主線程上執(zhí)行任務(wù)的。
 我們看看dispatch queue如何使用
1、常用的方法dispatch_async
為了避免界面在處理耗時(shí)的操作時(shí)卡死,比如讀取網(wǎng)絡(luò)數(shù)據(jù),IO,數(shù)據(jù)庫讀寫等,我們會(huì)在另外一個(gè)線程中處理這些操作,然后通知主線程更新界面。
 用GCD實(shí)現(xiàn)這個(gè)流程的操作比前面介紹的NSThread  NSOperation的方法都要簡(jiǎn)單。代碼框架結(jié)構(gòu)如下:
[cpp]
 dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
     // 耗時(shí)的操作
     dispatch_async(dispatch_get_main_queue(), ^{
         // 更新界面
     });
 });
如果這樣還不清晰的話,那我們還是用上兩篇博客中的下載圖片為例子,代碼如下:
[cpp]
 dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
     NSURL * url = [NSURL URLWithString:@"http://avatar.csdn.net/2/C/D/1_totogo2010.jpg"];
     NSData * data = [[NSData alloc]initWithContentsOfURL:url];
     UIImage *p_w_picpath = [[UIImage alloc]initWithData:data];
     if (data != nil) {
         dispatch_async(dispatch_get_main_queue(), ^{
             self.p_w_picpathView.p_w_picpath = p_w_picpath;
          });
     }
 });
運(yùn)行顯示:IOS GCD全解

目前創(chuàng)新互聯(lián)已為近1000家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬主機(jī)網(wǎng)站托管、企業(yè)網(wǎng)站設(shè)計(jì)、迭部網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

是不是代碼比NSThread  NSOperation簡(jiǎn)潔很多,而且GCD會(huì)自動(dòng)根據(jù)任務(wù)在多核處理器上分配資源,優(yōu)化程序。
系統(tǒng)給每一個(gè)應(yīng)用程序提供了三個(gè)concurrent dispatch queues。這三個(gè)并發(fā)調(diào)度隊(duì)列是全局的,它們只有優(yōu)先級(jí)的不同。因?yàn)槭侨值?,我們不需要去?chuàng)建。我們只需要通過使用函數(shù)dispath_get_global_queue去得到隊(duì)列,如下:
[cpp]
 dispatch_queue_t globalQ = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
這里也用到了系統(tǒng)默認(rèn)就有一個(gè)串行隊(duì)列main_queue
 [cpp]
 dispatch_queue_t mainQ = dispatch_get_main_queue();
雖然dispatch queue是引用計(jì)數(shù)的對(duì)象,但是以上兩個(gè)都是全局的隊(duì)列,不用retain或release。
2、dispatch_group_async的使用
dispatch_group_async可以實(shí)現(xiàn)監(jiān)聽一組任務(wù)是否完成,完成后得到通知執(zhí)行其他的操作。這個(gè)方法很有用,比如你執(zhí)行三個(gè)下載任務(wù),當(dāng)三個(gè)任務(wù)都下載完成后你才通知界面說完成的了。下面是一段例子代碼:
[cpp]
 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");
 });
 dispatch_group_async(group, queue, ^{
     [NSThread sleepForTimeInterval:3];
     NSLog(@"group3");
 });
 dispatch_group_notify(group, dispatch_get_main_queue(), ^{
     NSLog(@"updateUi");
 });
 dispatch_release(group);
 dispatch_group_async是異步的方法,運(yùn)行后可以看到打印結(jié)果:
2012-09-25 16:04:16.737 gcdTest[43328:11303] group1
 2012-09-25 16:04:17.738 gcdTest[43328:12a1b] group2
 2012-09-25 16:04:18.738 gcdTest[43328:13003] group3
 2012-09-25 16:04:18.739 gcdTest[43328:f803] updateUi
每個(gè)一秒打印一個(gè),當(dāng)?shù)谌齻€(gè)任務(wù)執(zhí)行后,upadteUi被打印。

3、dispatch_barrier_async的使用
dispatch_barrier_async是在前面的任務(wù)執(zhí)行結(jié)束后它才執(zhí)行,而且它后面的任務(wù)等它執(zhí)行完成之后才會(huì)執(zhí)行
 例子代碼如下:
[cpp]
 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");
 });

打印結(jié)果:
2012-09-25 16:20:33.967 gcdTest[45547:11203] dispatch_async1
 2012-09-25 16:20:35.967 gcdTest[45547:11303] dispatch_async2
 2012-09-25 16:20:35.967 gcdTest[45547:11303] dispatch_barrier_async
 2012-09-25 16:20:40.970 gcdTest[45547:11303] dispatch_async3
請(qǐng)注意執(zhí)行的時(shí)間,可以看到執(zhí)行的順序如上所述。
4、dispatch_apply
執(zhí)行某個(gè)代碼片段N次。
dispatch_apply(5, globalQ, ^(size_t index) {
     // 執(zhí)行5次
});

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

網(wǎng)站標(biāo)題:IOSGCD全解-創(chuàng)新互聯(lián)
標(biāo)題來源:http://muchs.cn/article4/ddojie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、定制網(wǎng)站、網(wǎng)站建設(shè)服務(wù)器托管、網(wǎng)頁設(shè)計(jì)公司小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)