尾递归

函数调用自身,称为『递归』;函数尾调用自身,称为『尾递归』

由于递归需要保存大量调用帧,很消耗内存,容易发生 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

你可能感兴趣的:(尾递归)