主任务并行运行,子任务依次运行。

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了主任务并行运行,子任务依次运行。相关的知识,希望对你有一定的参考价值。

所以我有一个用例,我有5个主任务,在主任务里面有3个子任务(比如异步IO操作)。主任务是独立的,而单个主任务中的子任务是相互依赖的。我可以顺序运行所有的任务,但这将是一个巨大的CPU时间浪费.我需要一种方法来使用async-await和Promise来并行运行所有的主任务,并在每个主任务内顺序运行子异步任务。

答案

我使用vanilla javascript得出的解决方案 async awaitPromise

async function myFunc() {
  const list = ["MainA:", "MainB:", "MainC:", "MainD:", "MainE:"];
  let allPromises = [];
  list.forEach(main => {
    allPromises.push(runSubTasks(main));
  });
  console.log("allPromises before settle:", allPromises);
  let data = await Promise.all(allPromises);
  console.log("allPromises after settle:", allPromises);
  console.log("resolved values inside allPromises:", data);
  // All main tasks are done by this point
}

myFunc();

async function runSubTasks(main) {
  const one = await asyncSubTask1(main, "");
  const two = await asyncSubTask2(main, one);
  return asyncSubTask3(main, two);
  // or
  // const three = await runTask3(main, two);
  // return three;
}

function asyncSubTask1(main, sub) {
  return new Promise((res, rej) => {
    setTimeout(() => {
      console.log(`${main}${sub}1`);
      res(`${sub}1`);
    }, Math.random() * 10000);
  });
}
function asyncSubTask2(main, sub) {
  return new Promise((res, rej) => {
    setTimeout(() => {
      console.log(`${main}${sub}2`);
      res(`${sub}2`);
    }, Math.random() * 10000);
  });
}
function asyncSubTask3(main, sub) {
  return new Promise((res, rej) => {
    setTimeout(() => {
      console.log(`${main}${sub}3`);
      res(`${main}${sub}3`);
    }, Math.random() * 10000);
  });
}

以上是关于主任务并行运行,子任务依次运行。的主要内容,如果未能解决你的问题,请参考以下文章

我需要从并行运行的任务中取消 redux saga 中的特定任务。使用下面的代码,所有并行任务都被取消

Flink5:Flink运行架构(Slot和并行度)

多任务原理

并行运行的最大任务量?

1-3 join方法

Java 分支合并(ForkJoin)