news 2026/4/17 16:36:36

前端js实现按添加顺序返回并发异步任务的执行结果

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
前端js实现按添加顺序返回并发异步任务的执行结果

题目:N个并发任务,异步执行,按照任务的添加顺序返回执行结果,而不是谁先执行完返回谁,保证并发任务的执行顺序。

给定下面的代码,要求实现ConRequests类。

//模拟异步请求functionmockRequest(name,delay){returnnewPromise((resolve)=>{setTimeOut(()=>{resolve(`任务{name}完成`)},delay)})}constrequests=newConRequests()constreq1=requests.add(mockRequest('A',3000))constreq2=requests.add(mockRequest('B',1000))constreq3=requests.add(mockRequest('C',2000))req1.then(console.log)//.then() 接收的是一个函数引用。等价于request1.then(((result)=>console.log(result));req2.then(console.log)req3.then(console.log)//输出://任务A完成//任务B完成//任务C完成

思路:
// 使用一个队列(数组)来记录所有已添加的任务 Promise。
// 维护一个 currentIndex 表示当前应返回第几个结果。
// 每个 Promise 完成后,将其结果存入一个结果数组。
// 一旦前面的结果都已就绪,就按顺序 resolve 对应的包装 Promise。

classConRequests{constructor(){this.requests=[]//存放请求{promise, resolve, reject}this.results=[]//存放执行结果this.currentIndex=0//当前能释放结果的索引}add(promise){returnnewPromise((resolve,reject)=>{//index作用:// 保证任务 A(index=0)、任务 B(index=1)、任务 C(index=2)的requests/results下标严格对应;// 即使 B 先完成(results[1] = 结果),但results[0]还是null(A 未完成),tryRelease会卡在currentIndex=0,直到 A 完成后才会依次释放 A、B、C。constindex=this.requests.lengththis.results[index]=null//占位,避免下标错乱this.requests.push(promise,resolve,reject)promise.then((result)=>{this.results[index]=result//更新结果this.tryRelease()//尝试释放已完成的连续结果}).catch((err)=>{this.results[index]=errthis.tryRelease()})})}tryRelease(){while(this.currentIndex<this.requests.length&&this.results[this.currentIndex]!==null){constresult=this.results[this.currentIndex]const{resolve,reject}=this.requests[this.currentIndex]if(resultinstanceofError){reject(result)}else{resolve(result)}this.currentIndex++}}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 5:14:10

ModEngine2游戏模组开发:从零开始的5步实战指南

ModEngine2游戏模组开发&#xff1a;从零开始的5步实战指南 【免费下载链接】ModEngine2 Runtime injection library for modding Souls games. WIP 项目地址: https://gitcode.com/gh_mirrors/mo/ModEngine2 游戏模组开发是现代游戏社区中极具创造性的技术领域&#xf…

作者头像 李华
网站建设 2026/4/18 8:41:41

建议Java后端面试都准备到这种程度再去...

引言 无论是刚刚毕业的学生&#xff0c;还是刚刚工作一两年面试经验比较少的同学&#xff0c;往往会比较困惑该如何准备面试。面对至少三轮面试&#xff08;或更多轮&#xff09;大公司面试都有什么要求&#xff0c;我来分享一下我的经验。 给自己明确一个目标&#xff0c;把…

作者头像 李华
网站建设 2026/4/18 8:35:50

Open WebUI数据可视化终极指南:如何快速解锁AI交互数据洞察力

Open WebUI数据可视化终极指南&#xff1a;如何快速解锁AI交互数据洞察力 【免费下载链接】open-webui Open WebUI 是一个可扩展、功能丰富且用户友好的自托管 WebUI&#xff0c;设计用于完全离线操作&#xff0c;支持各种大型语言模型&#xff08;LLM&#xff09;运行器&#…

作者头像 李华
网站建设 2026/4/18 8:37:27

为什么90%的多模态Agent项目在Docker依赖上踩坑?真相来了

第一章&#xff1a;多模态 Agent 的 Docker 依赖管理在构建多模态 Agent 应用时&#xff0c;Docker 成为统一开发、测试与部署环境的关键工具。由于多模态系统通常融合文本、图像、音频等多种处理模块&#xff0c;其依赖项复杂且易冲突&#xff0c;因此精确的依赖管理至关重要。…

作者头像 李华
网站建设 2026/4/17 21:28:59

仅限内部使用:高可用系统中Agent健康上报机制的机密设计模式

第一章&#xff1a;Docker Compose 的 Agent 服务健康报告在现代微服务架构中&#xff0c;确保服务的持续可用性至关重要。Docker Compose 提供了内置的健康检查机制&#xff0c;可用于监控 Agent 服务的运行状态。通过定义 healthcheck 指令&#xff0c;可以定期执行命令以判断…

作者头像 李华