第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會有你想問的

一個(gè)異步任務(wù)執(zhí)行樹,如何按照深度優(yōu)先遍歷的方法一次次執(zhí)行?

一個(gè)異步任務(wù)執(zhí)行樹,如何按照深度優(yōu)先遍歷的方法一次次執(zhí)行?

冉冉說 2018-11-12 12:15:33
如下圖這樣一個(gè)樹形結(jié)構(gòu)的異步樹。該怎么寫才能保證每個(gè)異步操作依次等待執(zhí)行。即上一個(gè)操作完成之后再執(zhí)行下一個(gè),后一個(gè)執(zhí)行可能會用到前一個(gè)執(zhí)行的返回結(jié)果。
查看完整描述

1 回答

?
MM們

TA貢獻(xiàn)1886條經(jīng)驗(yàn) 獲得超2個(gè)贊

可以用Promise實(shí)現(xiàn)。每個(gè)任務(wù)的結(jié)果用一個(gè)Promise保存,如果A依賴B則在B resolve之后才開始A.


const tasks = {

  a: {

    dep: ["b", "c"],

    run: (resultB, resultC) => resultB + resultC

  },

  b: {

    run: () => `B`

  },

  c: {

    dep: ["d"],

    run: resultD => `C` + resultD

  },

  d: {

    run: () => `D`

  },

};


const targetStack = [];


function run(taskTree, target, results = {}) {

  if (targetStack.indexOf(target) !== -1) {

    const err = new Error(`recursive dependicies: ${targetStack.concat([target]).join(" <- ")}`);

    targetStack.length = 0;

    throw err;

  }

  targetStack.push(target);

  const deps = (taskTree[target].dep || []).map(

    depName => results[depName] = results[depName] || run(taskTree, depName, results)

  );

  targetStack.pop();

  return Promise.all(deps).then(deps => taskTree[target].run.apply(undefined, deps));

}


run(tasks, "a").then(resultA => console.log(resultA));

(這個(gè)代碼其實(shí)不需要任務(wù)是樹形,只要求是無環(huán)圖)

查看完整回答
反對 回復(fù) 2018-12-03
  • 1 回答
  • 0 關(guān)注
  • 631 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號