JavaScript 尾调用

发布于 2022-11-24 23:55:03 字数 939 浏览 133 评论 0

外部函数的返回值是一个内部函数的返回值。

条件

  1. 代码在严格模式下执行
  2. 外部函数的返回值是对尾调用函数的调用
  3. 尾调用函数返回后不需要执行额外的操作
  4. 尾调用函数不是引用外部函数作用域中的闭包

优点

函数调用会在内存形成一个 调用帧,保存调用位置和内部变量等信息。由于尾调用是函数最后一步操作,所以不需要保留外层函数调用帧,这样每次执行时调用帧只有一项,大大节省内存

计算 n 的阶乘

普通递归

function factorialN (n) {
    return n === 0 ? 1 : n * factorialN(n - 1);
}

尾调用

function nVal (n, total) {
    if (n === 1) {
        return total;
    }
    return nVal(n - 1, n * total)
}

function factorialN (n) {
    return nVal(n, 1);
}

斐波那契数列

普通递归

function fib(n) {
    if (n < 2) {
        return n;
    }
    return fib(n - 1) + fib(n - 2);
}

尾调用

function fiber (a, b, n) {
    if (n === 0) {
        return a;
    }
    return fiber(b, a + b, n - 1);
}
function fib(n) {
    return fiber(0, 1, n);
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

文章
评论
29 人气
更多

推荐作者

櫻之舞

文章 0 评论 0

弥枳

文章 0 评论 0

m2429

文章 0 评论 0

野却迷人

文章 0 评论 0

我怀念的。

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文