当前位置: 首页 > news >正文

用Promise实现前端并发请求

/**
* 构造假请求
*/
async function request(url) {return new Promise((resolve) => {setTimeout(() => {resolve(url);},// Math.random() * 500 + 800,1000,);});
}

请求一次,查看耗时,预计应该是1s:

async function requestOnce() {const t1 = Date.now();const res = await request(1);console.log('一次请求耗时=', Date.now() - t1, 'ms,请求结果=', res);
}
requestOnce();

结果:在这里插入图片描述

12个数据发起并行请求,预计耗时1s:

async function requestAsync() {const t2 = Date.now();const requests = new Array(12).fill(2).map(request);const res2 = await Promise.all(requests);console.log('批量请求耗时=', Date.now() - t2, 'ms,请求结果=', res2, ',预计是 1000 ms');
}requestAsync();

结果:
在这里插入图片描述

12个请求并发进行,但限制最多3个请求可并发,预计耗时4s:

async function concurrencyRequest(urls, maxNum) {const buffer = [];//并发请求池,最多有maxNum个const t3 = Date.now();const res = [];for (let i = 0; i < urls.length && buffer.length < maxNum; ++i) {// console.log('next=', i);const promise = new Promise((resolve) => request(urls[i]).then(resolve));buffer.push(promise);promise.then((response) => (res[i] = response)).finally(() => {//每个请求完成后都从buffer中删除并保存响应const index = buffer.findIndex((item) => item === promise);buffer.splice(index, 1);// console.log('删除一个promise', buffer.length);});if (buffer.length === maxNum) {//必须等待buffer size小于maxNum才能继续请求await Promise.race(buffer);}}await Promise.all(buffer);//需要等待最后剩下的几个请求完成才算完成console.log('并发请求耗时=', Date.now() - t3, '请求结果=', res, '预计时间是 4000 ms');
}concurrencyRequest(new Array(12).fill(1).map((_, i) => i + 1),3,
);

在这里插入图片描述

http://www.lryc.cn/news/448106.html

相关文章:

  • 通过队列实现栈
  • Mac下可以平替paste的软件pastemate,在windows上也能用,还可以实现数据多端同步
  • 106. 从中序与后序遍历序列构造二叉树
  • 监控和日志管理:深入了解Nagios、Zabbix和Prometheus
  • Win10下载Python:一步步指南
  • Race Karts Pack 全管线 卡丁车赛车模型素材
  • C#——switch案例讲解
  • 技术美术一百问(02)
  • 12 函数的应用
  • 鸿蒙开发(NEXT/API 12)【硬件(接入手写套件)】手写功能开发
  • 基于python+flask+mysql的音频信息隐藏系统
  • 18724 二叉树的遍历运算
  • 代理模式简介:静态代理VS与动态代理
  • 使用 Dockerfile 和启动脚本注册 XXL-Job 执行器的正确 IP 地址
  • Python连接Kafka收发数据等操作
  • MySql在更新操作时引入“两阶段提交”的必要性
  • 充气模块方案——无刷充气泵pcba方案
  • [sql-03] 求阅读至少两章的人数
  • Linux如何通过链接下载文件
  • seL4 IPC(五)
  • 【Java】多线程基础操作
  • 基于Hive和Hadoop的病例分析系统
  • 数据结构编程实践20讲(Python版)—03栈
  • 【注册/登录安全分析报告:孔夫子旧书网】
  • PMP--二模--解题--141-150
  • 我的领域-关怀三次元成长的二次元虚拟陪伴 | OPENAIGC开发者大赛高校组AI创作力奖
  • 个人账号(学校+个人)申请专利过程中遇见的问题
  • 在ubuntu系统中,如何让其按下物理关机键时,系统不处理,但qt程序能检测到关机键按下的事件,并处理信号
  • 先进制造aps专题二十六 基于强化学习的人工智能ai生产排程aps模型简介
  • 各领域/行业硬件一览表