贝利信息

javascript的尾调用优化是什么_如何写出可优化的递归

日期:2025-12-23 00:00 / 作者:幻影之瞳
尾调用优化(TCO)是JS引擎将尾调用转为循环以避免栈溢出的机制,但仅Safari在严格模式下真正支持;尾调用指函数最后一步直接返回另一函数调用结果。

尾调用优化(Tail Call Optimization,TCO)是 JavaScript 引擎在满足特定条件时,将尾调用转换为循环以避免新增调用帧、防止栈溢出的机制。但要注意:目前只有 Safari 的 JavaScriptCore 引擎在严格模式下真正支持 TCO;V8(Chrome/Node.js)和 SpiderMonkey(Firefox)虽曾尝试实现,但已暂停或未启用。也就是说,写法上可以遵循尾调用规范,但不能依赖运行时一定优化

什么是尾调用?

尾调用指函数的最后一步操作是调用另一个函数(或自身),且该调用的返回值直接作为当前函数的返回值——中间不再做任何计算或处理。

✅ 正确的尾调用(尾递归):

function factorial(n, acc = 1) {
  if (n   return factorial(n - 1, n * acc); // 最后一步是调用自身,无后续运算
}

❌ 非尾调用(普通递归):

function factorial(n) {
  if (n   return n * factorial(n - 1); // 调用后还要乘 n,不是尾位置
}

如何写出可被优化的递归函数

实际开发中的建议