亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

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

一個異步任務執行樹,如何按照深度優先遍歷的方法一次次執行?

一個異步任務執行樹,如何按照深度優先遍歷的方法一次次執行?

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

1 回答

?
MM們

TA貢獻1886條經驗 獲得超2個贊

可以用Promise實現。每個任務的結果用一個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));

(這個代碼其實不需要任務是樹形,只要求是無環圖)

查看完整回答
反對 回復 2018-12-03
  • 1 回答
  • 0 關注
  • 638 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號