函数调用自身,称为『递归』;函数尾调用自身,称为『尾递归』
由于递归需要保存大量调用帧,很消耗内存,容易发生 stack overflow,所以可以把普通的递归函数改为只存在一个调用帧的尾递归:
普通写法:
function factorial(n) {
if (n === 1) return 1;
return n * factorial(n - 1);
}
factorial(5) // 120
改成:
function factorial(n, total) {
if (n === 1) return total;
return factorial(n - 1, n * total);
}
factorial(5, 1) // 120