JavaScript通过Promise来控制并发请求个数

本文探讨了在JavaScript中如何控制并发请求的数量,确保同一时间最多只有5个异步请求在运行,以避免资源过载。通过串行和并行的概念对比,解释了Promise.all可能导致的问题,并给出了实现并发限制的代码示例,保证请求顺序的同时,优化了大量请求的执行效率。
摘要由CSDN通过智能技术生成

一、场景

假设现在有这么一种场景:现有 30 个异步请求需要发送,但由于某些原因,我们必须将同一时刻并发请求数量控制在 5 个以内,同时还要尽可能快速的拿到响应结果。

如图所示:
在这里插入图片描述
上图这样的排队和并发请求的场景基本类似,窗口只有三个,人超过三个之后,后面的人只能排队了。

二、串行和并行

  • 串行:一个异步请求完了之后在进行下一个请求
  • 并行:多个异步请求同时进行

串行举例:

var p = function () {
   
  return new Promise(function (resolve, reject) {
   
    setTimeout(() => {
   
      console.log("1000");
      resolve();
    }, 1000);
  });
};
var p1 = function () {
   
  return new Promise(function (resolve, reject) {
   
    setTimeout(() => {
   
      console.log("2000");
      resolve();
    }, 2000)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值