有關(guān)并發(fā)異步請求的問題

最近項(xiàng)目中遇到了一個(gè)功能,會涉及到不少并發(fā)的請求,但是公司瀏覽器又不支持Promise母剥、async/await,正好趁此機(jī)會總結(jié)一下有關(guān)異步請求的處理方式形导。


簡化下項(xiàng)目中實(shí)際遇到的問題环疼,去掉其他的邏輯:

有一個(gè)最終包含n個(gè)子節(jié)點(diǎn)的xml對象

<rules>
    <rule1>....</rule1>
    <rule2>....</rule2>
    <rule3>....</rule3>
    .....
    <rulen>....</rulen>
</rules>

需要遍歷每個(gè)子節(jié)點(diǎn),每次遍歷到這個(gè)節(jié)點(diǎn)的時(shí)候朵耕,利用包括這個(gè)節(jié)點(diǎn)以及其prev的節(jié)點(diǎn)作為一個(gè)xml規(guī)則炫隶,去異步請求,最終拿到所有異步的結(jié)果去進(jìn)行下面的邏輯阎曹。
再簡化下伪阶,
遍歷一個(gè)數(shù)組煞檩,拿每一項(xiàng)作為參數(shù)去異步請求

var arr = [1,2,3,4,5,6,7,8,9];

需求:因?yàn)镴S事件循環(huán)的機(jī)制,后續(xù)執(zhí)行的同步代碼的需要之前所有異步操作的結(jié)果


方案一:并行改串行
最簡單的方法就是用回調(diào)栅贴,將每次的異步操作分別放到之前異步的回調(diào)里:

function async1(){
  async2()
}
function async2(){
  //....
}
async1();

優(yōu)點(diǎn):簡單
缺點(diǎn):總執(zhí)行時(shí)間是所有異步請求累加斟湃,可能會很長


方案二:用一個(gè)變量來計(jì)數(shù)

function async1(){
   callback()
}
function async2(){
  callback()
}
function callback(){
  cnt++
  if(2==cnt){
    console.log('都執(zhí)行完畢')
  }
}

方案三:在方案二中不用回調(diào)計(jì)數(shù),用定時(shí)器計(jì)數(shù)

var cnt = 0;
function async1(){
   cnt++
}
function async2(){
  cnt++
}
var interval = setInterval(function(){
  if(cnt==2){
    console.log("執(zhí)行完畢")
     clearInterval(interval);
  }
})

缺點(diǎn):定時(shí)器占用CPU較多


方案四:jquery的Deferred

var d1 = $.Deferred();
var d2 = $.Deferred();

function async1(){
d1.resolve( "Fish" );
}

function async2(){
d2.resolve( "Pizza" );
}

$.when( d1, d2 ).done(function ( v1, v2 ) {
console.log( v1 + v2 + '已完成');
});
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末檐薯,一起剝皮案震驚了整個(gè)濱河市凝赛,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌坛缕,老刑警劉巖墓猎,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異赚楚,居然都是意外死亡毙沾,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進(jìn)店門宠页,熙熙樓的掌柜王于貴愁眉苦臉地迎上來左胞,“玉大人,你說我怎么就攤上這事勇皇≌志洌” “怎么了焚刺?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我歉井,道長千元,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任蔓姚,我火速辦了婚禮捕虽,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘坡脐。我一直安慰自己泄私,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布备闲。 她就那樣靜靜地躺著晌端,像睡著了一般。 火紅的嫁衣襯著肌膚如雪恬砂。 梳的紋絲不亂的頭發(fā)上咧纠,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天,我揣著相機(jī)與錄音泻骤,去河邊找鬼漆羔。 笑死梧奢,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的演痒。 我是一名探鬼主播亲轨,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼嫡霞!你這毒婦竟也來了瓶埋?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤诊沪,失蹤者是張志新(化名)和其女友劉穎养筒,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體端姚,經(jīng)...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡晕粪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了渐裸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片巫湘。...
    茶點(diǎn)故事閱讀 40,872評論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖昏鹃,靈堂內(nèi)的尸體忽然破棺而出尚氛,到底是詐尸還是另有隱情,我是刑警寧澤洞渤,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布阅嘶,位于F島的核電站,受9級特大地震影響载迄,放射性物質(zhì)發(fā)生泄漏讯柔。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一护昧、第九天 我趴在偏房一處隱蔽的房頂上張望魂迄。 院中可真熱鬧,春花似錦惋耙、人聲如沸捣炬。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽湿酸。三九已至,卻和暖如春蒜田,著一層夾襖步出監(jiān)牢的瞬間稿械,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工冲粤, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留美莫,地道東北人页眯。 一個(gè)月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像厢呵,于是被迫代替她去往敵國和親窝撵。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,876評論 2 361

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

  • 1.ios高性能編程 (1).內(nèi)層 最小的內(nèi)層平均值和峰值(2).耗電量 高效的算法和數(shù)據(jù)結(jié)構(gòu)(3).初始化時(shí)...
    歐辰_OSR閱讀 29,418評論 8 265
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對...
    cosWriter閱讀 11,113評論 1 32
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理襟铭,服務(wù)發(fā)現(xiàn)碌奉,斷路器,智...
    卡卡羅2017閱讀 134,716評論 18 139
  • 1寒砖、通過CocoaPods安裝項(xiàng)目名稱項(xiàng)目信息 AFNetworking網(wǎng)絡(luò)請求組件 FMDB本地?cái)?shù)據(jù)庫組件 SD...
    陽明先生_X自主閱讀 15,988評論 3 119
  • 一大早起來赐劣,天氣就已經(jīng)很熱了,有陰涼的地方還能舒服一點(diǎn)哩都,若是太陽赤裸裸地照著你魁兼,即使打傘也不能避免高溫帶來的不適。...
    自然律閱讀 328評論 0 0