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),将其加入微任务队列。
  • 当前宏任务执行完毕后,立即清空微任务队列中所有任务,按先进先出顺序执行。
  • 微任务清空后,进入下一轮事件循环,取下一个宏任务执行。

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

实际例子:看懂输出顺序

来看一段经典代码:

console.log('start');

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

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

console.log('end');

输出结果为:

PathFinder
PathFinder

AI驱动的销售漏斗分析工具

下载
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

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

765

2023.08.10

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

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

765

2023.08.10

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

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

531

2023.06.20

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

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

576

2023.07.28

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

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

760

2023.08.03

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

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

6231

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()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

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

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