iOS中的多線程如何按設(shè)定順序去執(zhí)行任務(wù)詳解
多線程概述
對于ios系統(tǒng)中的某個App來講,是單進(jìn)程多線程方式來工作。一般來說,使用多線程的好處是可以把程序分成相對獨立的幾個模塊,可以有效的防止某個模塊堵塞的時候?qū)е抡麄€程序卡死;還有就是提高運行效率,現(xiàn)在CPU都是多核,多個核可以同時跑,可以同時執(zhí)行多條線程。
經(jīng)常有這樣的需求:
1,有m個網(wǎng)絡(luò)請求。
2,先并發(fā)執(zhí)行其中n幾個。
3,待這n個請求完成之后再執(zhí)行第n+1個請求。
4然后等 第n+1個請求完成后再并發(fā)執(zhí)行剩下的m-(n+1)個請求。
如果我們用GCD,可以使用dispatcg_barrier_async 來實現(xiàn),如下:
注意這里的queue 不能是 global_queue
注意:看圖片中注釋的哪一行代碼,dispatch_global 跟 dispatch_barrier 結(jié)合起來是起不到barrier 的作用的,查閱dispatch_barrier的開發(fā)者文檔我們發(fā)現(xiàn)如下一段描述:
意思是我們傳入的queue 需要時使用dispatch_queue_create創(chuàng)建出來的,如果我們傳的queue是 串行或 global,那這個方法的行為就跟 dispatch_sync差不多了,如果你對 dispatch_sync(同步執(zhí)行) 不甚了解,沒關(guān)系,你只需要知道,barrier 執(zhí)行的不再是我們預(yù)想的順序了,dispatch_sync 的一個特點是,放進(jìn)去任務(wù)就開始執(zhí)行。
如果我們用NSOpeartion,可以使用addDenpency 來實現(xiàn),如下:
可以看到這種方法雖然實現(xiàn)了設(shè)定順序,但是并不優(yōu)雅。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
IOS UITableView和UITableViewCell的幾種樣式詳細(xì)介紹
這篇文章主要介紹了IOS UITableView和UITableViewCell的幾種樣式詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2016-12-12實例講解iOS應(yīng)用的設(shè)計模式開發(fā)中的Visitor訪問者模式
這篇文章主要介紹了iOS應(yīng)用的設(shè)計模式開發(fā)中的Visitor訪問者模式的實例,示例代碼為傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-03-03iOS開發(fā)中實現(xiàn)郵件和短信發(fā)送的簡單示例
這篇文章主要介紹了iOS開發(fā)中實現(xiàn)郵件和短信發(fā)送的簡單示例,編程語言依然是傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-09-09iOS的UI開發(fā)中UITabBarControlle的基本使用教程
這篇文章主要介紹了iOS的UI開發(fā)中UITabBarControlle的基本使用教程,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-12-12