并发请求数量控制

概述

某些情况下,我们可能需要对需要执行的多个异步任务进行异步数量控制,只允许固定数量的任务执行,等待其中某些任务完成后,继续追加异步任务,直到将缓冲队列填满,最后执行完毕再停止。

代码

js 复制代码
class BufferControl {
  bufferList = []; //缓冲队列
  maxLen = 1; //当前允许执行的最大并发数量
  currentQueenCount = 0; //当前正在执行的任务数量
  add(fn) {
    this.bufferList.push(fn);
    this.run();
  }

  run() {
    if (!this.bufferList.length) {
      return;
    }
    while (this.bufferList.length && this.currentQueenCount < this.maxLen) {
      let fn = this.bufferList.shift();
      this.currentQueenCount++;
      fn().then(() => {
        this.currentQueenCount--;
        this.run();
      });
    }
  }
}

let queen = new BufferControl();

// 定义几个异步任务
let fn1 = () => {
  return new Promise((resolve) => {
    setTimeout(() => {
      console.log('fn1', 1000);
      resolve();
    }, 1000);
  });
};
let fn2 = () => {
  return new Promise((resolve) => {
    setTimeout(() => {
      console.log('fn2', 2000);
      resolve();
    }, 1000);
  });
};
let fn3 = () => {
  return new Promise((resolve) => {
    setTimeout(() => {
      console.log('fn3', 3000);
      resolve();
    }, 1000);
  });
};
let fn4 = () => {
  return new Promise((resolve) => {
    setTimeout(() => {
      console.log('fn4', 4000);
      resolve();
    }, 1000);
  });
};
// 追加到缓冲队列中
queen.add(fn1);
queen.add(fn2);
queen.add(fn3);
queen.add(fn4);

效果

最后的效果为每隔1秒打印一次异步任务的结果,4秒后执行完毕全部异步任务。

如果我们吧属性maxLen改为2,则会共计耗时2秒完成打印,每秒分别打印两次任务。

总结

当然,异步任务的个数和时间都不定,我们可以根据自己的需求,自行设置,最重要还是对Promise的深入理解.

相关推荐
|晴 天|16 分钟前
实现草稿自动保存功能:5秒无操作自动保存
前端·vue.js·typescript
小汪说干货21 分钟前
2026年4月最新|公众号文章插入文档附件3种技术方案
javascript·小程序
Cisyam^22 分钟前
Bright Data Web Scraping 指南:用 MCP + Dify 自动采集 TikTok 与 LinkedIn数据
大数据·前端·人工智能
qq_12084093711 小时前
Three.js 骨骼动画工程实战:AnimationMixer、剪辑与混合权重调参
开发语言·javascript·ecmascript
XGeFei1 小时前
【表单处理】——如何防止CSRF(跨站请求伪造)攻击的?
前端·网络·csrf
还不秃顶的计科生1 小时前
多模态模型下载
java·linux·前端
GISer_Jing1 小时前
笑不活了!蒸馏Skill竟能复刻前任、挽留同事?三大热门项目+完整地址汇总
前端·人工智能
Bigger2 小时前
🚀 mini-cc:打造你的专属轻量级 AI 编程智能体
前端·node.js·claude
小江的记录本2 小时前
【网络安全】《网络安全三大加密算法结构化知识体系》
java·前端·后端·python·安全·spring·web安全
早起傻一天~G2 小时前
vue2+element-UI上传图片封装
开发语言·javascript·ui