尾调用(Tail Call) 尾调用是函数式编程里比较重要的一个概念,它的意思是在函数的执行过程中,如果最后一个动作是一个函数的调用,即这个调用的返回值被当前函数直接返回,则称为尾调用,如下所示: function f(x) { return g(x) } 在 f 函数中,最后一步操作是调用 g 函数,并且调用 g 函数的返回值被 f 函数直接返回,这就是尾调用.而下面这个栗子就不是尾调用: function f(x) { return 1 + g(x) } 原因是它的最后一步操作是将 g 函数…
一般情况下,仅从代码上看只要不出现死循环,是不会出现堆栈调用溢出的.但是某些情况下列外,比如下面这段代码: var a = 99; function b (){ a --; if (a > 0){ b(); } else { console.info(a); } } b(); => 0 这并不是死循环,当变量 a逐渐减少到0时,递归就终止了.乍一看是不会出现任何问题的,但是如果我们把 a增加到一个较大的数值,就会出现问题: 如图所示,一个范围错误的异常抛了出来,我们被告知"超过了最大…