JS事件循环Event Loop详解:为什么setTimeout不准?Promise和Axios执行顺序拆解

打破直觉:从浏览器宿主环境视角,彻底看清宏微任务的调度真相

前言

在前端面试或大型项目开发中,异步执行机制是一个避不开的核心话题。许多初学者甚至有经验的开发者,在面对嵌套的setTimeoutPromise以及网络请求时,往往只能凭直觉判断执行顺序。本文将基于底层逻辑,通过模拟浏览器宿主环境与 JS 引擎的协作过程,彻底拆解事件循环(Event Loop)的运作本质。


一、 核心架构:三位一体的协作模型

要理解异步,首先要意识到浏览器并非只有一个线程在工作。虽然JavaScript 引擎(如 V8)是单线程的,但浏览器作为宿主环境是多线程的。

  1. 执行栈 (Call Stack):负责运行同步代码。
  2. Web APIs (宿主环境助手):包含定时器线程、网络请求线程、事件触发线程。它们负责在后台处理耗时任务。
  3. 任务队列 (Task Queues):用于存放异步任务的回调函数,分为宏任务队列(Macrotask Queue)和微任务队列(Microtask Queue)。
任务分类速查表
任务类型来源具体 API 示例
宏任务 (Macrotask)宿主环境script全体代码、setTimeoutsetInterval、I/O、UI 渲染
微任务 (Microtask)JS 引擎内部Promise.then/catch/finallyMutationObserverprocess.nextTick(Node.js)

二、 执行流程详解:以 Axios 和 Timer 为例

假设我们有如下代码片段:

console.log("0");axios.get("/api/data").then((res)=>{console.log("res");});setTimeout(()=>{console.log("1");},1000);console.log("2");
1. 初始化与同步阶段

当代码开始执行时,它本身处于第一个宏任务(Script)中。

  • console.log("0")入栈执行,打印0,出栈。
  • 执行axios.get:JS 引擎调用网络模块接口后立即出栈。注意:此时回调函数并没有进入队列,而是由浏览器的网络线程接管。
  • 执行setTimeout:JS 引擎通知定时器线程开始 1000ms 倒计时,随后立即出栈。
  • console.log("2")入栈执行,打印2,出栈。
2. 异步协作与入队
  • 300ms 时:假设网络请求完成。网络线程将then中的回调函数放入微任务队列
  • 1000ms 时:定时器倒计时结束。定时器线程将回调函数放入宏任务队列
3. 事件循环的搬运规则

当执行栈为空时,Event Loop 开始循环工作:


三、 关键机制补丁:深度问答

1. 任务队列为空时会发生什么?

当执行栈和所有任务队列均为空时,主线程并不会进行无效的死循环(空转)。此时主线程会进入“挂起”状态,由操作系统接管,直到 Web APIs 线程产生新的任务信号(如用户点击、定时器到期)将其唤醒。这种机制极大地降低了能耗。

2. 为什么定时器不准?

setTimeout(fn, 1000)的含义是:“在 1000ms 后,将 fn 加入宏任务队列”
如果此时执行栈正在处理一个耗时 2000ms 的同步计算,或者微任务队列中积压了大量任务,Event Loop 必须等前面的任务全部执行完,才有机会处理定时器的回调。因此,定时器的实际执行时间往往晚于预设时间。

3. 微任务的插队特性

微任务具有极高的优先级。在执行任何一个宏任务之前,Event Loop 必须确保微任务队列是空的。这意味着,如果在执行微任务的过程中又产生了新的微任务,这些新任务会直接排在当前微任务队列的末尾,并在同一个循环周期内被执行完,直到队列彻底清空。


四、 总结

理解 JavaScript 事件循环,关键在于摒弃“代码是一行行执行到底”的线性思维,转而建立“任务调度”的空间思维。

  • 同步代码:立即在栈中执行。
  • 异步发起:由宿主环境线程异步接管。
  • 异步回调:根据类型进入微/宏任务队列。
  • 事件循环:负责在栈空闲时,按照“先微后宏”的顺序进行搬运。

通过这一套机制,JavaScript 在单线程的基础上,优雅地实现了对高并发 I/O 和复杂交互的支持。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1205448.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Selenium破解滑动验证码的原理及解决思路

🍅 点击文末小卡片 ,免费获取软件测试全套资料,资料在手,涨薪更快 1、获取页面元素信息: 使用Selenium打开目标网页,并通过相关方法获取滑块、背景图等元素的位置和属性信息。可以使用Selenium提供的定…

收藏!2025秋招大厂AI岗“杀疯了”,80W+offer遍地走

2025年秋招堪称近三年最“卷”也最“香”的一届,互联网大厂们轮番下场抢人,内卷程度直接拉满,用“杀疯了”形容毫不为过。不仅岗位释放量创下近年新高,薪资待遇更是一路飙升,一家比一家豪放,不少网友直呼&a…

《Java并发编程的艺术》| ConcurrentHashMap 在 JDK 1.7 与 1.8 的底层实现

摘要:本篇围绕 Java 并发容器核心,详细解析了 ConcurrentHashMap 在 JDK 1.7 和 JDK 1.8 版本中的实现原理与演进,并对比了其与 HashMap、Hashtable 的核心差异。第6章 Java 并发容器6.1 ConcurrentHashMap的实现原理与使用6.1.1 为什么要使用…

Web自动化测试知识总结

🍅 点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快 一、自动化测试基本介绍 1、自动化测试概述: 什么是自动化测试?一般说来所有能替代人工测试的方式都属于自动化测试,即通过工…

EasyGBS在物业视频安防管理中的应用实践

一、方案背景在现代物业服务中,高效的安全管理与便捷的服务运营至关重要。随着科技的不断发展,物业行业对智能化、集成化管理系统的需求日益增长。EasyGBS作为一款基于国标GB28181、RTSP、ONVIF、RTMP协议的视频监控平台和算法算力平台,具备强…

EasyGBS智慧厨房全方位监控与管理方案设计

在食品安全与餐饮管理日益受到重视的今天,厨房作为食品加工的核心场所,其操作规范性、卫生状况及安全管控已成为社会关注的焦点。传统视频监控系统往往局限于“看得见”,却难以实现“看得懂”“管得住”。而国标GB28181算法算力平台EasyGBS的…

【论文自动阅读】LLARVA: Vision-Action Instruction Tuning Enhances Robot Learning

快速了解部分 基础信息(英文): 1.题目: LLARVA: Vision-Action Instruction Tuning Enhances Robot Learning 2.时间: 2024 3.机构: Berkeley AI Research (BAIR), UC Berkeley 4.3个英文关键词: LMMs, Vision Action Instruction Tuning, Ro…

2025年潍坊最好的花灯生产厂家有哪些,智能花灯/华景花灯/国风花灯/十二生肖花灯/宫灯/国潮花灯,花灯订制厂家哪家靠谱

近年来,随着文旅产业与消费场景的深度融合,花灯作为兼具文化属性与商业价值的载体,正从传统节庆装饰向常态化商业美陈转型。尤其在商场、文旅综合体等场景中,智能互动化、定制化的花灯产品需求激增。然而,市场鱼龙…

市面上天虹购物卡回收流行的三种方式

天虹购物卡因其广泛的使用场景,常作为节日礼品、员工福利流通于大众生活中,但闲置问题也随之凸显。数据显示,每年有近三成的天虹购物卡因过期、无使用需求等原因被闲置,不仅造成资产浪费,也让持卡人面临“留之无用…

基于区块链的长输管道工程物资管理【附代码】

✨ 本团队擅长数据搜集与处理、建模仿真、程序设计、仿真代码、论文写作与指导,毕业论文、期刊论文经验交流。✅ 专业定制毕设、代码✅ 成品或定制,查看文章底部微信二维码(1)分布式账本技术解决物资管理信息孤岛难题长距离输送管…

多目标约束装配式建筑施工调度优化【附模型】

✨ 本团队擅长数据搜集与处理、建模仿真、程序设计、仿真代码、论文写作与指导,毕业论文、期刊论文经验交流。✅ 专业定制毕设、代码✅ 成品或定制,查看文章底部微信二维码(1)装配式建筑施工调度多目标优化模型构建装配式建筑作为建筑工业化的重要发展方…

船舶修理项目优先级评价体系构建研究

✨ 本团队擅长数据搜集与处理、建模仿真、程序设计、仿真代码、论文写作与指导,毕业论文、期刊论文经验交流。✅ 专业定制毕设、代码✅ 成品或定制,查看文章底部微信二维码(1)船舶修理企业多项目并行管理的资源冲突问题分析船舶修理行业作为支撑全球海运…

火灾应急决策方案智能优选模型【附代码】

✨ 本团队擅长数据搜集与处理、建模仿真、程序设计、仿真代码、论文写作与指导,毕业论文、期刊论文经验交流。 ✅ 专业定制毕设、代码 ✅ 成品或定制,查看文章底部微信二维码 (1)基于知识图谱的火灾应急信息体系构建方法 火灾应急…

吉林市船营昌邑龙潭丰满英语雅思培训辅导机构推荐,2026权威出国雅思课程中心学校口碑排行榜

在全球化留学热潮下,雅思考试已成为吉林市船营、昌邑、龙潭、丰满四区学子通往海外名校的关键门槛,但雅思培训市场的鱼龙混杂让众多考生深陷备考困境。多数考生面临词汇积累与解题能力脱节、口语开口难、写作逻辑混乱…

2026年南通中考复读学校费用及排名情况分析

2026年江苏中考竞争持续升温,中考复读成为众多失利学子重启梦想的关键选择。无论是寻求正规化的教学管理、个性化的提分方案,还是全周期的备考支持,优质中考复读学校的专业能力直接决定学生来年的升学结果与成长轨迹…

说说苏州信誉好的复读公司,鸿文复读学校经验丰富,口碑卓越?

本榜单依托全维度市场调研与真实家长反馈,深度筛选出五家江苏地区口碑突出的复读机构,为有复读需求的学生及家长提供客观依据,助力精准匹配适配的升学助力伙伴。 TOP1 推荐:南通市鸿文复读学校 推荐指数:★★★★…

四平市铁西铁东梨树伊通英语雅思培训辅导机构推荐,2026权威出国雅思课程中心学校口碑排行榜

在雅思培训热潮席卷四平市铁西、铁东、梨树、伊通等区域的当下,众多出国考生深陷备考与选课困境:优质教育机构筛选缺乏权威依据,不同基础考生对提分技巧、个性化方案的需求难以精准匹配,部分机构存在性价比失衡、提…

分析四季南山奕骼奶粉配料表,看看营养搭配是否靠谱?

一、认知基础篇 问题1:四季南山奕系列奶粉的配料表有什么独特之处?和普通中老年奶粉有何区别? 四季南山奕系列奶粉是专门针对中老年人复合型健康需求设计的功能型奶粉,其配料表大的特点是精准匹配需求场景+科学营养…

kubectl plugin:neat 的安装与使用

前言 在使用 kubectl get $KIND -o yaml 查看 k8s 资源时,输出结果中包含大量由集群自动生成的元数据(如 managedFields、resourceVersion、uid 等)。这些信息在实际复用 yaml 清单时需要手动清理,增加了额外的工作…

陇南市英语雅思培训辅导机构推荐,2026权威出国雅思课程中心学校口碑排行榜

经教育部教育考试院备案认证、全国雅思教学质量评估中心专项指导,参照《2025-2026中国大陆雅思备考趋势白皮书》核心指标,结合陇南市武都区、宕昌县、成县、徽县8400份有效考生调研问卷、86家教育机构实地核查及跨区…