调用栈是JavaScript引擎管理函数执行的核心机制,负责记录执行位置、保障返回顺序、隔离局部环境;当递归无终止、嵌套过深或循环引用导致栈帧持续压入无法弹出时,便会触发“Maximum call stack size exceeded”错误。
调用栈是 JavaScript 引擎管理函数执行的核心机制,它让单线程环境能准确记住“当前在哪儿、下一步回哪儿、每个函数的变量在哪”。没有它,函数嵌套调用后就找不到回来的路,局部变量也会混乱。
记录执行位置:每次进入一个函数,引擎就在栈顶记下这个函数;
保障返回顺序:函数结束时,自动弹出栈顶,控制权交还给它下面那个函数;
隔离局部环境:每个函数的参数、let/const/var变量、this和作用域链,都封装在各自的栈帧里,互不干扰。
以 greet("Alice") 调用 createMessage(name) 为例:
greet("Alice"),创建 greet 的执行上下文,压入栈顶greet 内遇到 createMessage("Alice"),再创建其执行上下文,再次压入栈顶createMessage 执行完并返回值,它的栈帧立即弹出greet 中断点,继续执行 console.log,完成后也弹出这本质是栈空间被撑爆了。常见原因:
function foo() { foo(); },每调一次就压一层,永不出栈不用猜,直接看:
console.trace(),控制台会打印完整调用路径,比如 at createMessage (script.js:2) → at greet (script.js:5)