首页 > 解决方案 > 尾调用优化 (TCO) 在 Safari 中不起作用

问题描述

根据ES6 兼容性表,Safari 具有尾调用优化功能。试过了,它就像任何其他浏览器一样失败。我错过了什么吗?

function factorial(n, r = 1n) {
  return (n <= 1) ? r : factorial(n - 1n, n * r)
}

console.log(factorial(36000n))

Safari 输出:

RangeError:超出最大调用堆栈大小。

标签: javascriptrecursionfunctional-programmingsafaritail-recursion

解决方案


您需要在严格模式下运行程序。

"use strict";

function factorial(n, r = 1n) {
    return n <= 1n ? r : factorial(n - 1n, n * r);
}

console.log(factorial(36000n).toString());

为了使函数调用被视为正确的尾调用,需要满足四个条件。

  • 调用函数处于严格模式
  • 调用函数要么是普通函数,要么是箭头函数。
  • 调用函数不是生成器函数。
  • 被调用函数的返回值由调用函数返回。

资料来源:Michael Saboff 的 ECMAScript 6 Proper Tail Calls in WebKit


推荐阅读