0

0

JS事件循环机制解析_宏任务与微任务指南

betcha

betcha

发布时间:2025-11-16 13:12:06

|

384人浏览过

|

来源于php中文网

原创

事件循环先执行宏任务,再清空微任务队列。同步代码如console.log立即执行,settimeout等宏任务进入宏任务队列,promise.then等微任务进入微任务队列。当前宏任务结束后,依次执行所有微任务,之后再取下一个宏任务。async/await基于promise,await后续代码被视为微任务。例如:script start→async1 start→async2→script end→async1 end→timeout,因await将“async1 end”推入微任务队列,在本轮宏任务结束后执行。

js事件循环机制解析_宏任务与微任务指南

JavaScript 的事件循环机制是理解异步编程的关键。很多人在处理 setTimeoutPromiseasync/await 时会感到困惑,原因就在于没有搞清楚宏任务(Macrotask)和微任务(Microtask)的执行顺序。下面我们就来清晰地梳理这套机制。

事件循环基础:什么是宏任务与微任务?

JavaScript 是单线程语言,所有代码都在一个主线程上执行。为了实现异步操作而不阻塞主线程,JS 引入了事件循环机制。这个机制依赖两个任务队列:

  • 宏任务队列(Macrotask Queue):也叫任务队列,用于存放宏任务。常见的宏任务包括:setTimeoutsetIntervalI/O 操作UI 渲染script 标签中的整体代码
  • 微任务队列(Microtask Queue):优先级高于宏任务。常见的微任务包括:Promise.then/catch/finallyqueueMicrotaskMutationObserver浏览器环境)。

每次事件循环开始时,先执行当前宏任务中的同步代码,然后清空微任务队列,再取下一个宏任务执行,如此反复。

执行顺序规则:宏任务与微任务如何调度?

事件循环遵循以下流程:

  • 从宏任务队列中取出一个任务执行(比如 script 主代码块或 setTimeout 回调)。
  • 执行过程中遇到同步代码,直接运行。
  • 遇到微任务(如 Promise.then),将其加入微任务队列。
  • 当前宏任务执行完毕后,立即清空微任务队列中所有任务,按先进先出顺序执行。
  • 微任务清空后,进入下一轮事件循环,取下一个宏任务执行。

关键点是:每完成一个宏任务,就会把所有当前可用的微任务执行完。

实际例子:看懂输出顺序

来看一段经典代码:

Dreamhouse AI
Dreamhouse AI

AI室内设计,快速重新设计你的家,虚拟布置家具

下载
console.log('start');

setTimeout(() => {
  console.log('timeout');
}, 0);

Promise.resolve().then(() => {
  console.log('promise');
});

console.log('end');

输出结果为:

start
end
promise
timeout

解释:

  • “start” 是同步代码,最先输出。
  • setTimeout 是宏任务,被放入宏任务队列。
  • Promise.then 是微任务,进入微任务队列。
  • “end” 是同步代码,紧接着输出。
  • 当前宏任务(主 script)执行完,开始执行微任务,输出 “promise”。
  • 微任务清空后,进入下一轮事件循环,执行 setTimeout 回调,输出 “timeout”。

async/await 与微任务的关系

async 函数返回一个 Promise,而 await 后面的表达式完成后,其后续代码会被当作微任务处理。

async function async1() {
  console.log('async1 start');
  await async2();
  console.log('async1 end');
}

async function async2() {
  console.log('async2');
}

console.log('script start');

setTimeout(() => {
  console.log('timeout');
}, 0);

async1();

console.log('script end');

输出为:

script start
async1 start
async2
script end
async1 end
timeout

注意 “async1 end” 在 “script end” 之后输出,是因为 await 相当于把后面的代码包装成 Promise.then,属于微任务。

基本上就这些。掌握宏任务和微任务的执行时机,就能准确预测异步代码的输出顺序。不复杂但容易忽略细节。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

743

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

743

2023.08.10

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

534

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

718

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5996

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

492

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

219

2023.09.04

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

4

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号