当前位置: 首页 > 面试题库 >

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

程磊
2023-03-14
问题内容

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

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

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

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

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

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


问题答案:

正在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())


 类似资料:
  • 我想澄清这一点,因为文件对这一点不太清楚; 问题1:是顺序或并行处理所有promise?或者,更具体地说,它是否等同于运行像这样的连锁promise 或者是另一种算法,所有的,,,,,等等都同时被调用(并行),并且在所有解析(或一个拒绝)后立即返回结果? 问题2:如果都是并行运行的,有没有一种方便的方法可以依次运行iterable? 注意:我不想使用Q或Bluebird,而是所有原生ES6规范。

  • 我们有一个基于quartz的调度程序应用程序,每分钟运行大约1000个作业,这些作业平均分布在每分钟的几秒钟内,即每秒大约16-17个作业。理想情况下,这16-17个作业应该同时触发,但是我们的第一条语句,它只是记录执行的时间,任务的execute方法调用得很晚。假设从05:00到05:04,我们每分钟安排1000个工作。因此,理想情况下,计划在05:03:50的作业应该在05:03:50记录ex

  • 问题内容: 我们有一个基于石英的调度程序应用程序,该应用程序每分钟运行约1000个作业,每分钟的秒数均匀分布,即每秒约16-17个作业。理想情况下,这16-17个作业应同时触发,但是该作业的execute方法的第一个语句(仅记录执行时间)非常晚。例如,假设我们从05:00到05:04每分钟安排1000个作业。因此,理想情况下,计划在05:03:50进行的作业应该在05:03:50记录了execut

  • 问题内容: 假设我有以下代码: 输出是相同的线程名称,因此这里没有任何好处-我的意思是,只有一个线程可以完成所有工作。 里面是这段代码: 我知道如果“外部”流是并行的(可能会阻塞),则强制该属性,“外部”将不得不等待“ flatMap”完成,反之亦然(因为使用了相同的公共池),但是为什么 总是 强迫那个? 那是在以后的版本中 可能会 更改的事情之一吗? 问题答案: 有两个不同方面。 首先,只有一个

  • 在我的应用程序中,有多个企业。每个企业登录并做一些动作,如上传数据,然后Kafka生产者采取的数据,并发送到主题。另一方面,Kafka消费者使用来自主题的数据并执行业务逻辑。并保存到数据库中。在这种情况下,当单个企业登录时,一切都很完美。但当多个企业登录时,则Kafka依次消费。也就是说,我如何使过程并行?在多个客户端请求上。提前谢了。

  • 因为一次只能运行一条指令,并且假设CPU只运行这个进程。多线程难道不是线程之间快速的上下文切换,给人一种并行处理的错觉,但实际上并不是在处理吗? 那么,既然CPU要执行的指令数是一样的,不管是单线程还是多线程,完成的时间不应该是一样的吗?如果是,说明多线程是并行处理的一种方式不是错的吗?