Promise控制同时请求的数量

控制同时进行的请求数量代码实现

js 复制代码
async function runWithConcurrency(tasks, maxConcurrent) {  
    const results = []; // 存放所有任务的最终结果(Promise)  
    const activeTasks = []; // 当前正在执行的任务对应的Promise(用于跟踪)  

    for (const task of tasks) {  
        // 1. 创建代表当前任务的Promise。`() => task()` 确保任务在需要时才启动  
        const taskPromise = Promise.resolve().then(task);  
        results.push(taskPromise); // 保存结果,最后统一用 Promise.all 等  

        // 2. 创建任务完成后的清理操作:从 activeTasks 中移除自己  
        const removeFromActive = () => activeTasks.splice(activeTasks.indexOf(removeFromActive), 1);  
        activeTasks.push(removeFromActive); // 注意:这里存的是清理函数对应的Promise  

        // 3. 如果当前活跃任务数已达上限,就等任意一个完成  
        if (activeTasks.length >= maxConcurrent) {  
            await Promise.race(activeTasks); // 等 activeTasks 数组里任意一个Promise完成  
        }  

        // 4. 将清理操作与实际任务完成挂钩  
        taskPromise.then(removeFromActive, removeFromActive); // 无论成功失败都清理  
      }  

    // 5. 等待所有任务完成(无论是否在活跃池中)  
    return Promise.allSettled(results); // 或者用 Promise.all(results) 只关心成功  
}  

// 使用示例  
const userIds = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];  
const tasks = userIds.map(id =>() => (id));  

// 最多同时发出 3 个请求  
runWithConcurrency(tasks, 3).then(results => {  
    console.log('所有用户获取完成 (并发控制):', results);  
});
  • 这个函数会确保最多只有maxConcurrent个请求同时在进行。
  • 当一个请求完成,池子里有空位了,才会开始下一个请求。
相关推荐
vipbic8 分钟前
我也该升级了,陪伴了我7年的博客
前端
Lee川27 分钟前
RAG 实战:从一篇掘金文章出发,拆解检索增强生成的全链路
前端·人工智能·后端
Lee川40 分钟前
MCP 高德地图实战:当 AI 学会使用工具,一个协议如何重塑大模型的行动边界
前端·人工智能·后端
ZC跨境爬虫1 小时前
跟着 MDN 学CSS day_14:(尺寸调整技能测试与实战解析)
前端·css·ui·html·tensorflow
kyriewen1 小时前
用魔法打败魔法:我让AI替我去面试前端岗,AI面试官给我打了92分,还发了offer
前端·javascript·面试
IT_陈寒1 小时前
Redis批量删除踩了坑,原来DEL命令不是万能的
前端·人工智能·后端
lichenyang4531 小时前
鸿蒙聊天 Demo 练习 06:AI 思考气泡与 MVVM + Controller 结构重构
前端
Lkstar2 小时前
Vue keep-alive 原理全解:LRU 缓存策略、源码级理解
前端·vue.js·面试
会联营的陆逊2 小时前
html2canvas 1.4.1 在 iOS Safari 中生成图片卡住的问题排查与修复
前端
ZC跨境爬虫2 小时前
跟着 MDN 学CSS day_13 :(深入理解CSS中的元素尺寸调整)
前端·javascript·css·ui·html·tensorflow