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

JavaScript 同步异步机制和 Promise 原理实现笔记

题目描述如何实现一个函数对象满足给出的含异步操作且严格限制调用顺序的链式函数调用过程?arrange('aaa').wait(5).do('commit').waitFirst(3).execute();// wait 和 waitFirst 是异步操作// 要求输出为:start - output `wait 5s` - output `commit` - output 'wait 3s' - output 'aaa'思路为了实现严格限制调用顺序的链式异步操作,核心思想是将“定义执行流程”与“实际执行”分离。arrange('aaa')返回一个对象,该对象提供wait、waitFirst、do、execute等方法,每个方法都返回同一个实例以支持链式调用。关键在于理解wait(5).do('commit')这一写法:调用wait(5)时并不立即等待,而是向内部维护的任务队列中注册一个“延迟 5 秒”的异步任务,并立即返回当前对象,因此紧接着可以调用do('commit')再注册一个“输出 commit”的任务。也就是说,所有方法调用只是在“编排任务队列”,并不会阻塞后续方法的调用。只有最后调用execute()时,才会真正按顺序遍历队列,依次执行每个任务(异步任务会等待完成再执行下一个)。通过这种方式,调用顺序决定了任务在队列中的排列顺序,而执行顺序则由execute统一控制。对于异步等待(如wait和waitFirst),可以利用 Promise 实现,每个任务返回一个 Promise,在execute中通过async/await或reduce串联执行。同时,通过闭包捕获arrange的参数(如'aaa'),在队列执行完毕后输出该参数。这样既保证了链式调用的灵活性,又确保了异步操作的严格顺序。代码v1functionarrange(value){constqueue=[];return{wait(delay){queue.push(()={console.log(`wait${delay}s`);});// 注册同步函数queue.push(async()={// 注册异步函数awaitnewPromise((resolve)={setTimeout(()={resolve(true);},delay*1000);});});return{// 返回对象控制函数执行顺序do(name){queue.push(()={console.log(name);});// 注册同步函数return{waitFirst(delay2){queue.push(()={console.log(`wait${delay2}s`);});// 注册同步函数queue.push(async()={// 注册异步函数awaitnewPromise((resolve)={setTimeout(()={resolve(true);},delay2*1000);});});return{asyncexecute(){for(constfnofqueue){awaitfn();}console.log(value);}}},};},};},};}// testarrange('aaa').wait(5).do('commit').waitFirst(3).execute();思考代码V1版本通过嵌套返回对象控制链式调用顺序,存在层级冗余、扩展不便的问题;可先基于状态模式将嵌套的方法定义扁平化,通过状态机显式管控调用顺序(替代隐式的嵌套约束),再借助迭代器模式封装任务队列的执行逻辑,解耦“链式规则控制”与“任务执行”,实现代码简化与扩展能力提升。代码v2classTaskIterator{constructor(){this.tasks=[];// 任务队列}addTask(task){this.tasks.push(task);}asynciterate(){for(consttaskofthis.tasks){awaittask();}}}functionarrange(value){// 状态机:控制调用顺序(初始→wait→do→waitFirst)constSTATUS={START:0,WAIT_CALLED:1,DO_CALLED:2,WAIT_FIRST_CALLED:3,};letcurStatus=STATUS.START;constiterator=newTaskIterator();// 扁平化定义,无嵌套,方便扩展constapi={wait(delay){if(curStatus!==STATUS.START){thrownewError("Invalid order: wait must be called first!");}// 注册 wait 任务iterator.addTask(()=console.log(`wait${delay}s`));iterator.addTask(async()={awaitnewPromise((resolve)=setTimeout(resolve,delay*1000)

相关文章:

JavaScript 同步异步机制和 Promise 原理实现笔记

题目描述 如何实现一个函数对象满足给出的含异步操作且严格限制调用顺序的链式函数调用过程? arrange(aaa).wait(5).do(commit).waitFirst(3).execute(); // wait 和 waitFirst 是异步操作 // 要求输出为:start -> output `wait 5s` -> output `commit` -> output…...

日期字段不连续,还能正确计算同环比吗?

——PowerBI、Datafor、FineBI三大平台专业对比分析 数据分析在企业经营、决策制定中扮演着越来越核心的角色。环比、同比是数据分析中最常见的两个指标,能清晰表现业务的发展趋势。然而,现实业务数据中,日期字段不连续(如自然日…...

AI 时代,计算机专业学生该怎么学?难

整体排查思路 我们的目标是验证以下三个环节是否正常: 登录成功时:服务器是否正确生成了Session并返回了包含正确 JSESSIONID的Cookie给浏览器。 浏览器端:浏览器是否成功接收并存储了该Cookie。 后续请求:浏览器在执行查询等操作…...

【Prometheus】实战指南:使用basic_auth加固监控数据访问

1. 为什么需要为Prometheus添加basic_auth认证 最近几年,随着企业数字化转型的加速,监控系统已经成为IT基础设施中不可或缺的一部分。Prometheus作为云原生时代最流行的监控解决方案之一,被广泛应用于各类生产环境。但很多团队在部署Promethe…...

深入ALV交互:巧用modify_cell与协议内表实现跨行字段联动更新

1. ALV交互的核心挑战与解决方案 在SAP开发中,ALV(ABAP List Viewer)表格是最常用的数据展示和交互控件之一。但很多开发者都遇到过这样的难题:当用户修改某个单元格时,如何自动更新其他行甚至跨行的关联字段&#xff…...

Switch第三方控制器终极解决方案:sys-con完全指南

Switch第三方控制器终极解决方案:sys-con完全指南 【免费下载链接】sys-con Nintendo Switch sysmodule that allows support for third-party controllers 项目地址: https://gitcode.com/gh_mirrors/sy/sys-con 想让您的Xbox和PlayStation手柄在Switch上畅…...

AI时代新型的项目管理应该是什么样的?侣

AI训练存储选型的演进路线 第一阶段:单机直连时代 早期的深度学习数据集较小,模型训练通常在单台服务器或单张GPU卡上完成。此时直接将数据存储在训练机器的本地NVMe SSD/HDD上。 其优势在于IO延迟最低,吞吐量极高,也就是“数据离…...

如何快速解密网易云音乐NCM文件:终极免费转换工具完全指南

如何快速解密网易云音乐NCM文件:终极免费转换工具完全指南 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 还在为网易云音乐下载的NCM加密文件无法在其他播放器播放而烦恼吗?ncmdump是一款专业的NCM解密工具&…...

手把手教你用Python+sklearn生成classification_report,并一键导出可视化报告

Pythonsklearn自动化模型评估报告:从classification_report到可视化仪表盘 在数据科学项目的交付环节,如何将模型评估结果清晰呈现给非技术背景的决策者,往往比模型开发本身更具挑战性。传统打印classification_report的方式存在三个痛点&…...

别再写错Verilog三态门了!一个assign语句搞定FPGA双向IO(附仿真避坑指南)

Verilog三态门实战指南:从代码误区到仿真验证 双向IO设计是FPGA开发中绕不开的经典问题,而三态门作为实现双向传输的核心元件,其代码写法看似简单却暗藏玄机。不少工程师在项目后期才发现三态门行为异常,仿真结果与预期不符&#…...

2026届必备的五大AI论文工具横评

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 技术人工智能的发展速度飞快,论文AI类网站成了可辅助学术写作领域的重要工具&…...

如何用Bitfocus Companion将普通硬件打造成专业控制中心:开源解决方案的三大突破

如何用Bitfocus Companion将普通硬件打造成专业控制中心:开源解决方案的三大突破 【免费下载链接】companion Bitfocus Companion enables the Elgato Stream Deck and other controllers to be a professional shotbox surface for an increasing amount of differ…...

XXMI启动器终极指南:一站式管理所有二次元游戏模组

XXMI启动器终极指南:一站式管理所有二次元游戏模组 【免费下载链接】XXMI-Launcher Modding platform for GI, HSR, WW and ZZZ 项目地址: https://gitcode.com/gh_mirrors/xx/XXMI-Launcher 还在为《原神》、《崩坏:星穹铁道》、《鸣潮》、《绝区…...

炉石传说脚本终极指南:从零开始掌握自动化对战

炉石传说脚本终极指南:从零开始掌握自动化对战 【免费下载链接】Hearthstone-Script Hearthstone script(炉石传说脚本) 项目地址: https://gitcode.com/gh_mirrors/he/Hearthstone-Script 你是否曾经梦想过有一个得力的助手&#xff…...

【HTML动态交互实战】模拟股市波动可视化系统

1. 从零搭建股市波动可视化系统 最近在做一个金融数据分析的小项目,需要模拟股票价格波动并可视化展示。作为一个前端开发者,我第一时间想到用HTML5 Canvas来实现这个需求。下面就把我的实现思路和踩过的坑分享给大家。 先说说为什么要用Canvas而不是S…...

Terminator进阶技巧:如何为特定命令定制自动补全规则(Ubuntu环境)

Terminator进阶技巧:如何为特定命令定制自动补全规则(Ubuntu环境) 在终端操作中,自动补全功能就像一位默契的助手,能显著提升命令行效率。对于经常与Terminator打交道的开发者而言,系统默认的补全规则往往无…...

ag-Grid 动态合并单元格实战:基于条件样式的行合并技巧

1. 初识ag-Grid合并单元格 第一次看到ag-Grid的合并单元格效果时,我正为一个客户管理系统头疼——表格里重复的省份和性别字段让数据显得杂乱无章。直到发现rowSpan这个神奇属性,才明白原来数据表格可以像Excel那样优雅地合并相同内容。 ag-Grid的合并单…...

零代码实战:在钉钉群聊中一键唤醒影刀RPA机器人

1. 为什么要在钉钉群聊里唤醒影刀RPA? 想象一下这个场景:每天早上9点,销售总监在群里数据机器人,5秒后就能收到自动生成的昨日销售报表。这种"聊天即操作"的体验,正是影刀RPA与钉钉联动带来的办公革命。我帮…...

工业五官:09 传感器最容易坏在哪里?工程师最怕的10个坑

09 传感器最容易坏在哪里?工程师最怕的10个坑 传感器这“小五官”,平时不显山露水,可一罢工,整条产线立马“瞎了眼”。我见过一个接近传感器松了,传送带空跑了俩小时,损失好几万。师傅们常说:“传感器坏了比人感冒还麻烦!”今天咱不讲高大上的理论,就聊安装、校准、故…...

终极免费内容解锁工具:简单三步绕过所有付费墙限制

终极免费内容解锁工具:简单三步绕过所有付费墙限制 在数字化信息时代,你是否经常遇到这样的情况:一篇深度分析文章正看到关键处,突然弹出付费订阅提示?一个技术教程刚进入核心步骤,却被付费墙完全阻挡&…...

无人机APM实战:从串口调试到多协议通信配置

1. 无人机APM串口通信基础入门 第一次接触APM飞控的串口通信时,我完全被各种专业术语搞懵了。后来才发现,串口其实就是飞控与外部设备"对话"的通道,就像两个人用对讲机交流一样简单。以Nora飞控为例,它的每个串口都有特…...

aibiye的AI改写工具通过五项措施,帮助30%重复率论文快速合规。采用语义扩展、数据强化等技术,精准降低相似度,提升稿件质量。

嘿,大家好!我是AI菌。今天咱们来聊聊一个让无数学生头疼的问题:论文重复率飙到30%以上怎么办?别慌,我这就分享5个实用降重技巧,帮你一次搞定,轻松压到合格线以下。这些方法都是我亲身试验过的&a…...

面对30%的论文重复率,aibiye的AI工具提出五条降重策略。自动优化引用格式、调整语序结构,使文本更符合原创标准,减少人工干预。

论文重复率超过30%时,可以通过多种方法有效降低重复率。调整句子结构、替换同义词、转换表达方式是常见的人工降重手段,能够在不改变原意的前提下显著减少重复内容。采用图表展示数据、增加案例分析等技巧,既能丰富论文形式又能降低重复率。合…...

<实战指南>从RSOD数据集到YOLO模型:遥感图像目标检测全流程解析

1. RSOD数据集初探:遥感目标检测的黄金样本库 第一次接触遥感图像目标检测时,我和大多数初学者一样,面对五花八门的数据集不知从何下手。直到遇见RSOD这个"小而美"的经典数据集,才真正打开了正确的研究方式。这个包含93…...

BilibiliDown:三步搞定B站视频下载,打造你的个人离线视频库

BilibiliDown:三步搞定B站视频下载,打造你的个人离线视频库 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader 😳 项目地址: https://gitcode.…...

Pixel Dimension Fissioner 环境部署详解:在Ubuntu服务器上从零开始配置

Pixel Dimension Fissioner 环境部署详解:在Ubuntu服务器上从零开始配置 1. 准备工作:系统与硬件要求 在开始部署Pixel Dimension Fissioner之前,我们需要确保服务器满足基本要求。根据官方文档和实际测试经验,以下是推荐配置&a…...

智能解锁付费内容:信息获取革命的完整解决方案

智能解锁付费内容:信息获取革命的完整解决方案 在当今数字化信息时代,你是否也曾面临优质内容被付费墙阻挡的困扰?智能解锁付费内容技术作为信息获取领域的重要突破,正在重新定义我们的阅读体验。通过创新的技术架构,这…...

数据可视化如何落地?一篇讲清楚数据可视化应用

其实大部分人一开始学数据可视化,最容易卡在一个地方,就是学了不少图表类型,真到工作里却不知道该怎么用。经常会问:这张图到底该怎么做,这些数据到底该怎么展示,这样展示是不是对业务真有帮助?…...

万象视界灵坛详细步骤:自定义候选标签+动态血条置信度解析教程

万象视界灵坛详细步骤:自定义候选标签动态血条置信度解析教程 1. 教程概述 万象视界灵坛是一款基于OpenAI CLIP技术的高级多模态智能感知平台,它将复杂的语义对齐过程转化为直观的像素风交互体验。本教程将手把手教你如何使用该平台的两个核心功能&…...

量化交易回测实战:如何用Backtrader-PyQt-UI实现10倍策略开发效率

量化交易回测实战:如何用Backtrader-PyQt-UI实现10倍策略开发效率 【免费下载链接】backtrader-pyqt-ui 项目地址: https://gitcode.com/gh_mirrors/bac/backtrader-pyqt-ui 在量化交易领域,传统回测工具往往面临两大痛点:要么是命令…...