html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

JavaScript支持的最大递归调用次数分析_javascript技巧_

[ ] 已经帮助:人解决问题

你对JavaScript引擎能进行多少次递归调用好奇吗?sGQHTML5中文学习网 - HTML5先行者学习网

多少次递归调用sGQHTML5中文学习网 - HTML5先行者学习网

下面的函数可以让你找到答案: (灵感来自Ben Alman的 gist)sGQHTML5中文学习网 - HTML5先行者学习网

复制代码 代码如下:
sGQHTML5中文学习网 - HTML5先行者学习网
function computeMaxCallStackSize() {sGQHTML5中文学习网 - HTML5先行者学习网
    try {sGQHTML5中文学习网 - HTML5先行者学习网
        return 1 + computeMaxCallStackSize();sGQHTML5中文学习网 - HTML5先行者学习网
    } catch (e) {sGQHTML5中文学习网 - HTML5先行者学习网
        // Call stack overflowsGQHTML5中文学习网 - HTML5先行者学习网
        return 1;sGQHTML5中文学习网 - HTML5先行者学习网
    }sGQHTML5中文学习网 - HTML5先行者学习网
}
sGQHTML5中文学习网 - HTML5先行者学习网

三个结果:sGQHTML5中文学习网 - HTML5先行者学习网

复制代码 代码如下:
sGQHTML5中文学习网 - HTML5先行者学习网
Node.js: 11034sGQHTML5中文学习网 - HTML5先行者学习网
Firefox: 50994sGQHTML5中文学习网 - HTML5先行者学习网
Chrome: 10402
sGQHTML5中文学习网 - HTML5先行者学习网

这些数字代表什么?Aleph先生指出,在V8中,递归调用的数量取决于两个量:堆栈的大小和堆栈帧(保存参数的局部变量)的大小。你可以通过在  computeMaxCallStackSize() 添加局部变量进行验证 - 它会返回低位值。sGQHTML5中文学习网 - HTML5先行者学习网

在ECMAScript 6中的尾部调用(Tail call)优化sGQHTML5中文学习网 - HTML5先行者学习网
sGQHTML5中文学习网 - HTML5先行者学习网
ES6 有尾部调用优化 :如果一个函数中的最后一步也是一个函数调用,它会被“跳”过,而不是通过子函数调用。这就意味着在ES6(严格模式)下,你只要稍微改一下computeMaxCallStackSize函数,它就可以永远执行下去。sGQHTML5中文学习网 - HTML5先行者学习网

复制代码 代码如下:
sGQHTML5中文学习网 - HTML5先行者学习网
function computeMaxCallStackSize(size) {sGQHTML5中文学习网 - HTML5先行者学习网
    size = size || 1;sGQHTML5中文学习网 - HTML5先行者学习网
    return computeMaxCallStackSize(size + 1);sGQHTML5中文学习网 - HTML5先行者学习网
}
sGQHTML5中文学习网 - HTML5先行者学习网
sGQHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助