在函数内部调用函数名

Calling function name inside function

本文关键字:函数 调用 内部      更新时间:2023-09-26

有一些概念我仍然不能在Javascript中弄清楚。比如这个。我在搜索一个返回两个整数的最大公约数的函数时遇到了这段代码。我测试了它,但我不明白这是如何返回gcd的。请理解的人解释一下return gcd(b, a % b);在这里做什么?

    var gcd = function(a, b) {
    if ( ! b) {
        return a;
    }
    return gcd(b, a % b);
};

您正在使用递归,这是一种使用不同参数再次调用同一函数的模式,直到找到退出条件,然后递归停止。

// exit condition
if (!b) {
    return a;
}

在这种情况下,再次调用函数,将参数b移动为a,并将a模取b作为新参数b

// call function again with different parameters
return gcd(b, a % b);