一尘不染

Node.js本机Promise.all是并行还是顺序处理?

node.js

我想澄清这一点,因为文档对此不太清楚。

问题1:Promise.all(iterable)按顺序还是并行处理所有承诺?或者,更确切地说,是相当于运行像

p1.then(p2).then(p3).then(p4).then(p5)....

或者是一些其他类型的算法的所有p1p2p3p4p5,等是被称为在同一时间(并行)和结果尽快返回所有的决心(或一个不合格品)?

问题2: 如果Promise.all并行运行,是否有方便的方法可以依次运行可迭代程序?

注意 :我不想使用Q或Bluebird,而是要使用所有本机ES6规范。


阅读 279

收藏
2020-07-07

共1个答案

一尘不染

正在Promise.all(iterable)执行的所有承诺?

不,诺言不能“被执行”。它们在 创建 时就开始执行任务-它们仅代表结果-并且
在并行执行所有操作之前甚至将其传递给它们Promise.all

Promise.all只会 等待 多个承诺。它不在乎它们以什么顺序解析,也不管计算是否并行运行。

是否有一种方便的方法来顺序运行迭代?

如果您已经有了承诺,那么您将无能为力,但是Promise.all([p1, p2, p3, …])(没有顺序的概念)。但是,如果您确实具有可迭代的异步函数,则实际上可以按顺序运行它们。基本上你需要从

[fn1, fn2, fn3, …]

fn1().then(fn2).then(fn3).then(…)

解决此问题的方法是使用Array::reduce

iterable.reduce((p, fn) => p.then(fn), Promise.resolve())
2020-07-07