Promise限制并发数

//promise并发限制
class PromisePool{
  constructor(max,fn){
    this.max=max;//最大并发量
    this.fn=fn;//自定义的请求函数
    this.pool=[];//并发池
    this.urls=[];//剩余的请求地址
  }
  start(urls){
    this.urls=urls;//先循环把并发池塞满
    while (this.pool.length<this.max){
      let url=this.urls.shift();
      this.setTask(url);
    }
    //利用Promise.race方法来获得并发池中某任务完成的信号
    let race=Promise.race(this.pool);
    return this.run(race);
  }
  run(race){
    race
      .then(res=>{
        //每当并发池跑完一个任务,就再塞入一个任务
        let url=this.urls.shift();
        this.setTask(url);
        return this.run(Promise.race(this.pool));
      })
  }
  setTask(url){
    if(!url)return
    let task=this.fn(url);
    this.pool.push(task);//将该任务推入pool并发池中
    console.log(`\x1B[43m ${url} 开始,当前并发数:${this.pool.length}`)
    task.then(res=>{
      //请求结束后将该Promise任务从并发池中移除
      this.pool.splice(this.pool.indexOf(task),1);
      console.log(`\x1B[43m ${url} 结束,当前并发数:${this.pool.length}`);
    })
  }
}
//test
const URLS=[
  'bytedance.com',
  'tencent.com',
  'alibaba.com',
  'microsoft.com',
  'apple.com',
  'hulu.com',
  'amazon.com'
]
//自定义请求函数
var requestFn=url=>{
  return new Promise(resolve=>{
    setTimeout(()=>{
       resolve(`任务${url}完成`)
    },1000*dur++)
  }).then(res=>{
    console.log('外部逻辑',res);
  })
}
const pool=new PromisePool(5,requestFn);//并发数为5
pool.start(URLS)
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现 `promise.map` 并限制 promise并发数,可以使用 `Promise.all` 结合 `Promise.race` 来实现。 首先,将要处理的数据数组分割成多个小数组,每个小数组的长度等于并发数。然后,使用 `Array.map` 方法对每个小数组创建一个 Promise,将 Promise 存放在一个新的数组中。 接下来,使用 `Promise.all` 来等待所有 Promise 完成,并返回一个新的 Promise。在这个新的 Promise 中,使用 `Promise.race` 来限制并发数,每次只执行指定数量的 Promise。当其中一个 Promise 完成时,会触发 `Promise.race` 返回的 Promise,然后继续执行下一个 Promise,以此类推。 下面是一个示例的实现代码: ```javascript function promiseMap(array, concurrency, mapper) { const chunks = []; for (let i = 0; i < array.length; i += concurrency) { chunks.push(array.slice(i, i + concurrency)); } const promises = chunks.map(chunk => { return Promise.all(chunk.map(mapper)); }); return Promise.all(promises).then(results => { return [].concat(...results); }); } ``` 使用示例: ```javascript const data = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]; function asyncTask(item) { return new Promise(resolve => { setTimeout(() => { console.log(`Processing item: ${item}`); resolve(item * 2); }, 1000); }); } promiseMap(data, 3, asyncTask).then(results => { console.log('All tasks completed:', results); }); ``` 在上述示例中,`promiseMap` 函数将 `data` 数组中的每个元素传递给 `asyncTask` 函数进行处理,并限制并发数为 3。输出结果会按照并发限制的顺序进行处理,每个任务间隔 1 秒执行。 这样,你就可以实现一个带有并发限制的 `promise.map` 函数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值