尾调用优化

Posted aizzz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了尾调用优化相关的知识,希望对你有一定的参考价值。

尾调用指的是函数作为另一个函数的最后一条语句被调用。

技术分享图片

 

在ES5的引擎中,尾调用的实现和其他函数调用实现类似:

创建一个新的栈帧,将其推入调用栈来表示函数调用,也就是说,在循环调用中,每一个未用完的栈帧都会被保存在内存中

当调用栈变得过大时会造成程序问题

 

ES6中的尾调用优化

ES6缩减了严格模式下尾调用栈的大小(非严格模式不受影响)

如果满足以下条件,尾调用将不再创建新的栈帧,而是清除并且重用当前栈帧。

(1)尾调用不访问当前栈帧的变量(也就是说函数不是一个闭包)

(2)在函数内部,尾调用是最后一条语句

(3)尾调用的结果作为函数值返回

 

以上是关于尾调用优化的主要内容,如果未能解决你的问题,请参考以下文章

尾调用优化

尾调用及递归优化

iOS 的尾调用优化原理

iOS 的尾调用优化原理

尾调用优化

为啥代码会主动尝试阻止尾调用优化?