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

为什么 Promise 比 setTimeout 先执行?——JavaScript 事件循环与异步顺序完全指南

为什么 Promise 比 setTimeout 先执行——JavaScript 事件循环与异步顺序完全指南这是 JavaScript 异步中最经典也最容易困惑的问题之一。核心答案是Promise 的回调属于 Microtask微任务setTimeout 属于 Macrotask宏任务。微任务队列会在当前宏任务执行完毕后、下一个宏任务开始前被清空。1. JavaScript 事件循环Event Loop核心模型2026 年最新标准JavaScript 是单线程语言但通过事件循环实现了异步。执行流程极简版执行同步代码主线程执行完当前宏任务后清空所有微任务Microtask Queue执行下一个宏任务Macrotask重复以上过程两大任务队列对比队列类型名称常见 API执行时机优先级Macrotask宏任务setTimeout,setInterval,setImmediate, I/O, UI渲染, MessageChannel当前事件循环周期结束后较低Microtask微任务Promise.then/catch/finally,queueMicrotask,MutationObserver,process.nextTick(Node)当前宏任务结束后、下一个宏任务前立即执行最高关键规则每次事件循环只会执行一个宏任务但会执行所有微任务直到队列为空微任务中新增的微任务也会在本次继续执行可能导致微任务饥饿2. 经典示例解析console.log(1);// 同步setTimeout((){console.log(2);// 宏任务},0);Promise.resolve().then((){console.log(3);// 微任务});console.log(4);// 同步输出顺序1 4 3 2执行过程同步代码执行 → 输出1、4当前宏任务结束 → 清空微任务队列 → 输出3进入下一个事件循环 → 执行setTimeout→ 输出23. 更完整的异步顺序表console.log(同步1);setTimeout(()console.log(setTimeout),0);Promise.resolve().then((){console.log(Promise1);returnPromise.resolve();}).then(()console.log(Promise2));queueMicrotask(()console.log(queueMicrotask));(async(){console.log(async start);awaitPromise.resolve();console.log(async end);// await 后的代码是微任务})();console.log(同步2);典型输出顺序同步1 同步2 async start Promise1 queueMicrotask Promise2 async end setTimeout4. async/await 的本质async/await是Promise 的语法糖await后面的代码会被包装成Promise.then微任务await Promise.resolve()也会让后续代码进入微任务队列asyncfunctiontest(){console.log(A);awaitPromise.resolve();console.log(B);// 相当于 .then 中的代码}test();console.log(C);// 输出A → C → B5. 实际开发中的重要结论与最佳实践微任务适合立即执行但不阻塞渲染的逻辑DOM 更新后的回调状态更新后的连锁操作错误处理宏任务适合需要延迟或分批执行的逻辑防抖、节流UI 渲染后操作setTimeout(..., 0)长时间任务拆分避免微任务饥饿// 错误示例可能卡死页面functionrecursion(){Promise.resolve().then(recursion);}手动控制任务类型// 强制放入宏任务setTimeout((){...},0);// 强制放入微任务queueMicrotask((){...});Node.js vs 浏览器Node.js 有process.nextTick比微任务还早Node.js 事件循环阶段更多timers → pending → poll → check 等6. 面试/调试技巧在 Chrome DevTools 中使用Performance面板录制可清晰看到 Microtask 和 Macrotask。使用console.trace()在回调中查看调用栈。理解requestAnimationFrame在渲染前属于宏任务但特殊。一句话总结同步代码 所有微任务Promise、await、queueMicrotask 宏任务setTimeout、I/O掌握了微任务 vs 宏任务你就真正理解了 JavaScript 异步的核心机制。想继续深入吗我可以接着给你写完整浏览器/Node.js 事件循环阶段图解async/await 原理与常见陷阱并发控制、错误处理手写 Promise 微任务调度模拟生产中异步任务调度最佳实践p-limit、async-pool 等告诉我你目前最想深入哪一部分

相关文章:

为什么 Promise 比 setTimeout 先执行?——JavaScript 事件循环与异步顺序完全指南

为什么 Promise 比 setTimeout 先执行?——JavaScript 事件循环与异步顺序完全指南 这是 JavaScript 异步中最经典也最容易困惑的问题之一。核心答案是: Promise 的回调属于 Microtask(微任务),setTimeout 属于 Macro…...

AI编程工具的内卷:Copilot、Cursor、通义灵码,谁能笑到最后?

当“内卷”的风吹到AI编程工具2026年,AI编程工具已不再是新鲜事物,而是开发者工具箱中的标配。从最初的代码补全,到如今的全栈智能体,这个赛道正经历着一场前所未有的“内卷”。GitHub Copilot、Cursor、通义灵码三足鼎立&#xf…...

感应照明技术:从工业到家用,一场技术降维的工程冒险

1. 项目概述:当感应照明技术走进寻常百姓家最近在整理一些老旧的行业资料时,翻到了2014年的一则新闻,讲的是当时一家初创公司“Finally Light Bulb Company”宣布要推出一款售价低于10美元的感应灯泡,用来替代传统的白炽灯。这让我…...

从RISC-V到SSITH:构建下一代硬件安全架构的开放之路

1. 项目概述:从“亡羊补牢”到“未雨绸缪”的硬件安全范式转移在智能设备无处不在的今天,我们正面临一个尴尬的现实:许多产品的安全设计,更像是在一栋已经建好的毛坯房里,见缝插针地安装防盗门和监控摄像头。这种“事后…...

横空出世!IDEA最强MyBatis插件来了,功能很全!

最近更新了IDEA 2026.1这个版本,发现之前使用的MyBaitsX这个插件没有兼容,启动就报错!于是就改用了MyBatisCodeHelper-Pro这个插件,体验了一把,提示很全,还有方便的MyBaits日志转SQL面板,这里分…...

彻底解放Windows 11任务栏:TranslucentTB透明化完全指南

彻底解放Windows 11任务栏:TranslucentTB透明化完全指南 【免费下载链接】TranslucentTB A lightweight utility that makes the Windows taskbar translucent/transparent. 项目地址: https://gitcode.com/gh_mirrors/tr/TranslucentTB 你是否厌倦了Windows…...

LLamaSharp实战指南:在.NET应用中本地部署与集成大语言模型

1. 项目概述:LLamaSharp,一个让大语言模型在本地跑起来的C#利器 如果你是一名C#或.NET开发者,最近肯定被ChatGPT和各种大语言模型(LLM)刷屏了。但你是否想过,不依赖OpenAI的API,不担心网络延迟…...

RE3SIM系统:3D真实感仿真数据生成技术解析

1. RE3SIM系统概述:3D真实感仿真数据生成新范式在机器人操作领域,获取高质量训练数据一直是制约算法发展的瓶颈。传统基于真实环境的示教数据采集不仅需要昂贵硬件支持,还依赖专业操作人员,单次任务采集成本可达数千元。RE3SIM系统…...

claw-gatekeeper:构建稳定智能的数据抓取守护服务

1. 项目概述:一个守护数据抓取流程的“看门人”在数据驱动的时代,无论是市场分析、舆情监控还是学术研究,自动化数据抓取(爬虫)都扮演着至关重要的角色。然而,任何稍有规模的抓取任务,都绕不开几…...

TS-182快速打通Modbus干变温控箱与PROFINET PLC连接

项目背景:在电力配电系统中,干式变压器的安全运行离不开温控箱的实时监测与保护。作为变压器温控箱的生产厂商,您是否遇到过这样的困扰:客户现场的主控系统采用西门子S7-1500 PLC(PROFINET协议)&#xff0c…...

逆光也能精准识别人脸,门禁不再卡壳

人脸门禁普及的路上,安全质疑从未停止:照片能不能骗过摄像头?视频冒充会不会被放行?尤其在学校、幼儿园、医院等需要高度核验身份的场所,一丁点伪冒漏洞都可能酿成风险。ZUU中优云联ZU-YK751人脸识别门禁终端&#xff…...

若依框架菜单管理实战:手把手教你为列表页添加详情页(Vue+Element UI)

若依框架菜单管理实战:手把手教你为列表页添加详情页(VueElement UI) 在后台管理系统开发中,列表页与详情页的联动是基础但关键的功能需求。许多开发者在使用若依框架的代码生成器快速搭建项目后,常常面临一个典型问题…...

自动化生产管理平台(Automatic)

1&#xff0c;自动化生产管理平台(Automatic) 1.1&#xff0c;重新定义Window样式 添加WindowChrome元素进行自定义定义 <Window x:Class"lzg.Automatic.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"…...

【最新版】heic格式转换器下载教程 livp格式转jpg超详细图文转换教程

文章目录准备工作安卓手机拍摄的heic格式转jpg教程苹果heic格式转jpg专用工具livp格式转jpg教程heic格式文件无法打开的原因及解决方法heic转换jpg后文件变大是什么原因本文将详细教你实现heic格式转jpg与livp格式转jpg的操作方法&#xff0c;同时免费提供实用的heic格式转换器…...

WeChatMsg:微信聊天记录本地化解析与多格式导出技术方案

WeChatMsg&#xff1a;微信聊天记录本地化解析与多格式导出技术方案 【免费下载链接】WeChatMsg 提取微信聊天记录&#xff0c;将其导出成HTML、Word、CSV文档永久保存&#xff0c;对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/WeC…...

3分钟学会!用Video-subtitle-extractor轻松提取视频硬字幕,告别手动转录烦恼

3分钟学会&#xff01;用Video-subtitle-extractor轻松提取视频硬字幕&#xff0c;告别手动转录烦恼 【免费下载链接】video-subtitle-extractor 视频硬字幕提取&#xff0c;生成srt文件。无需申请第三方API&#xff0c;本地实现文本识别。基于深度学习的视频字幕提取框架&…...

机器学习在资产管理中的应用:从数据到投资组合的端到端框架

1. 项目概述&#xff1a;当机器学习遇见资产管理如果你在资产管理行业待过&#xff0c;或者对量化投资感兴趣&#xff0c;那你肯定不止一次想过&#xff1a;那些复杂的市场数据、财报、新闻&#xff0c;能不能让机器来帮我们分析&#xff0c;甚至做出决策&#xff1f;firmai/ma…...

2025年项目管理工具TOP10:Gitee引领技术驱动新浪潮

1.Gitee&#xff08;码云&#xff09;&#xff1a;代码与管理的双核引擎 作为中国最大的代码托管平台&#xff0c;Gitee在2025年全面升级项目管理模块&#xff0c;成为技术团队的首选工具。其核心优势在于&#xff1a; 开发与协作无缝衔接&#xff1a;代码提交直接关联任务看板…...

积分、微分、指数和对数运算放大电路基础知识及Multisim电路仿真

目录 2.5 积分运算放大电路 2.5.1 积分运算放大电路基础知识 一、电路结构 二、核心原理与公式 三、关键特性 四、典型应用场景 2.5.2 积分运算放大电路Multisim电路仿真 2.5.2.1 输入方波 2.5.2.2 输入三角波 2.5.2.3 输入正弦波 2.6 微分运算放大电路 2.6.1 微分…...

AI 短剧系统快速部署,轻量化搭建,小白也能轻松运营落地

当下 AI 短剧创业已成热门轻资产赛道&#xff0c;很多个人创业者、中小团队想入局&#xff0c;却卡在开发周期长、技术门槛高、后台复杂难运营等问题。 一套AI 短剧系统支持极速快速部署&#xff0c;无需专业技术功底&#xff0c;搭建流程极简&#xff0c;运营门槛极低&#xf…...

Next-Enterprise:基于Next.js的企业级应用启动模板全解析

1. 项目概述&#xff1a;为什么说 Next-Enterprise 是“企业级”的&#xff1f;如果你正在用 Next.js 开发一个中后台管理系统、一个 SaaS 应用&#xff0c;或者任何需要“开箱即用”的现代企业级功能的应用&#xff0c;那么你大概率经历过这样的场景&#xff1a;项目初始化后&…...

PaspberryPi推流

1. 创建启动脚本sudo nano /usr/local/bin/rtsp-stream.sh添加内容&#xff1a;#!/bin/bash# RTSP 音视频推流服务脚本 # 适配 Raspberry Pi 3B Camera Module USB 麦克风# 配置项 WIDTH1280 HEIGHT720 FRAMERATE15 VIDEO_BITRATE2000000 AUDIO_DEVICE"hw:1,0" …...

ChatGPT Instagram内容策略失效真相(92%运营者忽略的算法适配层)

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;ChatGPT Instagram内容策略失效的底层归因 Instagram 的算法演进与用户行为迁移&#xff0c;正系统性瓦解基于通用大模型&#xff08;如 ChatGPT&#xff09;生成的“模板化内容策略”。其失效并非源于…...

EchoType开源键盘固件:基于状态感知的智能输入引擎深度解析

1. 项目概述&#xff1a;从“EchoType”看开源键盘固件的深度定制最近在键盘客制化圈子里&#xff0c;一个名为“EchoType”的项目开始被一些资深玩家频繁提及。它的GitHub仓库地址是ljyou001/echotype&#xff0c;从名字上你就能猜到&#xff0c;这大概率是一个与键盘固件、打…...

安卓全局音效处理:RootlessJamesDSP原理、配置与调优实战

1. 项目概述&#xff1a;在移动音频领域实现高自由度音效处理如果你是一名对手机音质有追求的发烧友&#xff0c;或者是一位喜欢折腾系统级音频设置的安卓用户&#xff0c;那么“RootlessJamesDSP”这个名字你很可能不会陌生。简单来说&#xff0c;这是一个无需获取安卓系统最高…...

3个关键策略:qmcdump如何高效解密QQ音乐加密音频文件

3个关键策略&#xff1a;qmcdump如何高效解密QQ音乐加密音频文件 【免费下载链接】qmcdump 一个简单的QQ音乐解码&#xff08;qmcflac/qmc0/qmc3 转 flac/mp3&#xff09;&#xff0c;仅为个人学习参考用。 项目地址: https://gitcode.com/gh_mirrors/qm/qmcdump 你是否…...

哔哩下载姬DownKyi:B站视频下载的终极免费解决方案

哔哩下载姬DownKyi&#xff1a;B站视频下载的终极免费解决方案 【免费下载链接】downkyi 哔哩下载姬downkyi&#xff0c;哔哩哔哩网站视频下载工具&#xff0c;支持批量下载&#xff0c;支持8K、HDR、杜比视界&#xff0c;提供工具箱&#xff08;音视频提取、去水印等&#xff…...

别再搞混了!DCI-P3、Display P3、sRGB色彩空间到底差在哪?给设计师和开发者的实用指南

别再搞混了&#xff01;DCI-P3、Display P3、sRGB色彩空间到底差在哪&#xff1f;给设计师和开发者的实用指南 打开设计软件的色彩配置选项&#xff0c;你是否曾被DCI-P3、Display P3、sRGB这些术语搞得晕头转向&#xff1f;当客户抱怨"这个红色在手机上看起来不一样"…...

尤克里里的前世今生:这把“跳蚤小吉他”,凭什么火遍全世界?

提到尤克里里&#xff0c;大家脑海里瞬间浮现的&#xff0c;一定是阳光、沙滩、草裙舞、海风与欢快旋律的画面&#xff01;这把小小的四弦乐器&#xff0c;颜值清新、音色治愈&#xff0c;上手零门槛&#xff0c;不管是小朋友启蒙、成年人解压&#xff0c;还是旅行随手弹&#…...

如何用3分钟搞定视频字幕提取?揭秘这款本地化硬字幕提取神器

如何用3分钟搞定视频字幕提取&#xff1f;揭秘这款本地化硬字幕提取神器 【免费下载链接】video-subtitle-extractor 视频硬字幕提取&#xff0c;生成srt文件。无需申请第三方API&#xff0c;本地实现文本识别。基于深度学习的视频字幕提取框架&#xff0c;包含字幕区域检测、字…...