0

0

javascript中事件循环是什么_宏任务和微任务有何区别

夢幻星辰

夢幻星辰

发布时间:2025-12-27 08:39:07

|

182人浏览过

|

来源于php中文网

原创

javascript事件循环是单线程下调度异步任务的核心机制,通过执行栈、宏任务队列和微任务队列协同工作:先执行同步代码,再清空全部微任务,最后取一个宏任务进入下一轮;微任务(如promise.then)总在当前宏任务结束前执行完毕,宏任务(如settimeout)则需等待下一轮循环。

javascript中事件循环是什么_宏任务和微任务有何区别

JavaScript 事件循环是单线程环境下调度异步任务的核心机制。它不靠多线程并发,而是通过“执行 + 两个队列(宏任务队列、微任务队列)+ 循环检查”的方式,让异步代码有序、非阻塞地运行。

事件循环的基本流程

主线程按以下固定节奏运转:

  • 先执行当前宏任务中的所有同步代码(比如整个 script 脚本、一次点击回调)
  • 同步代码执行完,立即清空当前所有的微任务(Promise.then、queueMicrotask、MutationObserver 等)——一个不剩,全部执行完才停
  • 微任务队列空了,再从宏任务队列中取出**第一个**任务(如 setTimeout 回调、下一次用户点击、I/O 完成通知),开始下一轮
  • 重复上述三步,持续循环

宏任务和微任务的关键区别

区别不在“谁更先进”或“谁更快”,而在于执行时机和优先级规则

灵枢SparkVertex
灵枢SparkVertex

零代码AI应用开发平台

下载
  • 宏任务:代表一次相对完整、独立的执行单元。例如:整体 script 标签内容、setTimeout/setInterval 回调、用户事件(click、input)、fetch 响应处理、页面渲染(浏览器端)
  • 微任务:代表必须在当前宏任务结束前立刻完成的小型后续操作。例如:Promise.then/catch/finally 回调、queueMicrotask() 注册的函数、MutationObserver 回调、Node.js 中的 process.nextTick()
  • 即使 setTimeout 设为 0ms,它的回调仍是宏任务,一定排在本轮所有微任务之后
  • 一个宏任务里可以产生多个微任务,它们会累积到微任务队列,等本轮同步代码一结束就全执行

为什么这样设计

微任务优先级更高,是为了保障关键逻辑的及时响应:

立即学习Java免费学习笔记(深入)”;

  • Promise 链式调用需要尽快衔接,避免被 UI 渲染或定时器打断
  • MutationObserver 要在 DOM 更新后、页面重绘前捕获变化,确保视图与数据一致
  • 避免开发者手动用 setTimeout(0) 模拟“下一轮”,减少不确定性

一个典型执行顺序示例

这段代码的输出顺序是 1 → 4 → 10 → 7 → 8 → 9 → 3 → 2:

  • 1、4、10、7 是同步代码,按序输出
  • 8、9 是 Promise.then 的微任务,在同步结束后立即执行(注意 8 里又注册了 9)
  • 3 是 queueMicrotask,也是微任务,排在所有 Promise.then 之后(同属微任务队列,先进先出)
  • 2 是 setTimeout,属于宏任务,要等本轮彻底结束、进入下一轮事件循环才执行

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

429

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

599

2023.08.10

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

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

723

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

372

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

27

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

25

2026.01.21

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

101

2026.02.06

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

372

2025.12.24

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

24

2026.02.28

热门下载

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

精品课程

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

共58课时 | 5.6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.2万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

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

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