尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

JS、浏览器——栈和队列(事件循环相关)

JS、浏览器——栈和队列(事件循环相关)
📅 发布时间:2026/6/26 6:46:21
  • 调用栈(Call Stack):这是一个栈(LIFO,后进先出)结构,记录当前正在执行的函数。它属于执行上下文管理知识。

  • 任务队列(Task Queue):这是一个队列(FIFO,先进先出)结构,存放等待执行的回调函数。它属于调度策略知识。

它们共同组成了事件循环的两个核心角色:“栈”负责当前做什么,“队列”负责接下来要做什么。

在这里,我们只学习栈和队列的相关内容,涉及到事件循环的知识可移步我的另一篇文章【浏览器——事件循环】

一、js引擎执行代码过程

  1. 引擎先执行所有同步代码(填满并清空调用栈)。

  2. 遇到异步API(如setTimeout、fetch),引擎不等待,直接交给Web APIs(浏览器提供)去处理(处理后的回调函数会放在队列中,等待调用),自己继续执行后续代码。

  3. 当调用栈完全清空后,事件循环才会从任务队列中取出回调函数,压入调用栈执行。

二、任务队列

任务队列包含两类:微任务队列和宏任务队列。

宏任务:由宿主环境(浏览器/Node)发起的任务

微任务:由 JS 引擎自身发起的任务,优先级高于宏任务

宏任务微任务

setTimeout

setInterval

setImmediate(Node)

I/O操作

UI 渲染

MessageChannel

...

Promise.then()/catch()/finally()

async/await(实质是 Promise)

MutationObserver(浏览器)

process.nextTick(Node,优先级最高)

...

三、执行机制

记住这句口诀:“一个宏任务,一筐微任务”。

在每一轮事件循环中,执行机制是这样的:

  1. 从宏任务队列中取出一个最旧的任务执行。
  2. 执行完毕后,检查微任务队列。
  3. 清空(执行完)微任务队列中的所有任务。
  4. 进入下一轮循环,再取下一个宏任务。

关键点:微任务会在下一个宏任务开始之前全部执行完毕。

相关新闻

  • 【课程设计/毕业设计】基于 SpringBoot + 小程序的美妆电商综合管理平台 数字化美妆门店线上服务小程序 美妆商品智能推荐与购物交易系统设计与实现【附源码、数据库、万字文档】
  • 第三卷:《组合逻辑:没有记忆的“直肠子”侠客》
  • Element UI el-upload 多文件上传踩坑与解决方案

最新新闻

  • Python asyncio 性能调优与陷阱
  • 微软推送Windows 11蓝牙功能大更新 修复大量漏洞并优化AirPods配对
  • 剪辑气口工具哪个好用,2026年剪气口工作流,5款深度对比
  • 华为认证2026最全攻略:我帮人选课踩过的那些坑,说出来都是泪
  • 嵌入式GUI开发实战:emWin 2D图形库核心API与优化技巧解析
  • 企业加密文件解密指南:从天锐蓝盾原理到合规操作实践

日新闻

  • Qwen2.5-Turbo百万上下文实战指南:百炼平台长文本处理全解析
  • 怎么监控对标账号更新,2026年作者监控工作流,5款深度对比
  • EdgeRemover:专业级Windows Edge浏览器管理工具,彻底解决顽固软件卸载难题

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号