JS 底层探究-- 调用栈(Call Stack)

1. 一句话定义

调用栈 = JS 引擎用来记录「当前正在执行谁」「接下来要执行谁」的栈结构

遵循规则:后进先出(LIFO)

2. 执行规则

  1. 代码一开始运行全局执行上下文 先入栈
  2. 调用函数 :该函数的执行上下文入栈,JS 立刻执行它
  3. 函数执行完 :该函数上下文出栈,回到上一层
  4. 整个程序结束:全局上下文最后出栈,调用栈清空

例子

TypeScript 复制代码
// 全局上下文
console.log("全局开始");

function a() {
  console.log("函数 a 执行");
  b(); // 调用函数 b
}

function b() {
  console.log("函数 b 执行");
}

a(); // 调用函数 a
console.log("全局结束");

4. 调用栈的作用

  • 保证 JS 单线程、同步执行
  • 追踪函数执行位置
  • 报错时能看到调用栈轨迹(Chrome 控制台里的 stack trace)

总结

  • 调用栈 :管理执行上下文的后进先出栈结构
  • 执行流程:全局入栈 → 函数入栈 → 函数出栈 → 全局最后出栈
  • 核心意义 :决定 JS 代码谁先执行、谁后执行
相关推荐
弹简特1 小时前
【Java项目-轻聊】08-用户管理模块-实现获取用户信息+头像上传+显示头像
java·开发语言·springboot
vickycheung31 小时前
RK182X 如何在 RK3588 上进行应用测试
开发语言·php
子午2 小时前
基于DeepSeek的智能校园教务管理系统~Web管理系统+Vue3+Python+DeepSeek智能问答
前端
change_fate2 小时前
ERR_PNPM_WORKSPACE_PKG_NOT_FOUND In ...
java·服务器·前端
超人不会飞_Jay2 小时前
26.6.3Vue笔记
前端·vue.js·笔记
御坂100272 小时前
Vue - @change应用实现下拉框联动功能
前端·javascript·vue.js
小雨下雨的雨2 小时前
基于 Electron 运行时的鸿蒙PC桌面应用-安全可靠的随机密码生成工具
前端·javascript·华为·electron·前端框架·鸿蒙
瘦瘦瘦大人2 小时前
Vue 项目实现关闭/刷新浏览器窗口前的离开确认提示
前端·javascript·vue.js
大家的林语冰2 小时前
尤雨溪官宣:Vite+ 全员加盟 Cloudflare,正式进军全栈开发和 AI 部署云平台!
前端·javascript·vite