JavaScript支持的最大遞歸調(diào)用次數(shù)分析
你對JavaScript引擎能進(jìn)行多少次遞歸調(diào)用好奇嗎?
多少次遞歸調(diào)用
下面的函數(shù)可以讓你找到答案: (靈感來自Ben Alman的 gist)
function computeMaxCallStackSize() {
try {
return 1 + computeMaxCallStackSize();
} catch (e) {
// Call stack overflow
return 1;
}
}
三個(gè)結(jié)果:
Node.js: 11034
Firefox: 50994
Chrome: 10402
這些數(shù)字代表什么?Aleph先生指出,在V8中,遞歸調(diào)用的數(shù)量取決于兩個(gè)量:堆棧的大小和堆棧幀(保存參數(shù)的局部變量)的大小。你可以通過在 computeMaxCallStackSize() 添加局部變量進(jìn)行驗(yàn)證 - 它會(huì)返回低位值。
在ECMAScript 6中的尾部調(diào)用(Tail call)優(yōu)化
ES6 有尾部調(diào)用優(yōu)化 :如果一個(gè)函數(shù)中的最后一步也是一個(gè)函數(shù)調(diào)用,它會(huì)被“跳”過,而不是通過子函數(shù)調(diào)用。這就意味著在ES6(嚴(yán)格模式)下,你只要稍微改一下computeMaxCallStackSize函數(shù),它就可以永遠(yuǎn)執(zhí)行下去。
function computeMaxCallStackSize(size) {
size = size || 1;
return computeMaxCallStackSize(size + 1);
}
- 詳解Javascript函數(shù)聲明與遞歸調(diào)用
- js匿名函數(shù)作為函數(shù)參數(shù)詳解
- Javascript自執(zhí)行匿名函數(shù)(function() { })()的原理淺析
- 淺析Javascript匿名函數(shù)與自執(zhí)行函數(shù)
- Javascript中匿名函數(shù)的調(diào)用與寫法實(shí)例詳解(多種)
- Javascript中的匿名函數(shù)與封裝介紹
- js中匿名函數(shù)的創(chuàng)建與調(diào)用方法分析
- 詳談JavaScript 匿名函數(shù)及閉包
- JS遍歷數(shù)組和對象的區(qū)別及遞歸遍歷對象、數(shù)組、屬性的方法詳解
- JavaScript采用遞歸算法計(jì)算階乘實(shí)例
- JavaScript中匿名函數(shù)的遞歸調(diào)用
相關(guān)文章
js操作table中tr的順序?qū)崿F(xiàn)上移下移一行的效果
這篇文章主要介紹了js操作table中tr的順序?qū)崿F(xiàn)上移下移一行的效果 ,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-11-11
手機(jī)端點(diǎn)擊圖片放大特效PhotoSwipe.js插件實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了手機(jī)端點(diǎn)擊圖片放大特效PhotoSwipe.js插件實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08
knockoutjs模板實(shí)現(xiàn)樹形結(jié)構(gòu)列表
這篇文章主要介紹了knockoutjs模板實(shí)現(xiàn)樹形結(jié)構(gòu)列表的實(shí)現(xiàn)代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2017-07-07
淺析$(function) ready和onload 的區(qū)別
新手剛學(xué)習(xí)js和jq的時(shí)候難免會(huì)接觸題目所標(biāo)識(shí)的相關(guān)內(nèi)容,下面小編通過本教程給大家講解(function) ready和onload 的區(qū)別,感興趣的朋友一起看看吧2016-09-09

