JS數(shù)組在內(nèi)存中的效率問(wèn)題淺析
JS數(shù)組
我們所熟知的JS數(shù)組的結(jié)構(gòu)和其他語(yǔ)言數(shù)組結(jié)構(gòu)類似,即物理內(nèi)存是連續(xù)的,所以這也就導(dǎo)致了數(shù)組成員移動(dòng)次數(shù)越少,其效率越高,一般數(shù)組會(huì)被分配到一段連續(xù)的內(nèi)存中,像這樣

大家可能會(huì)疑問(wèn),你為啥要給畫一個(gè)邊框呢,其實(shí)我們的數(shù)組在定義的時(shí)候默認(rèn)了它的長(zhǎng)度,即當(dāng)我們像要在數(shù)組中添加元素的時(shí)候,就需要對(duì)它的長(zhǎng)度做出改變。
效率比較
JS提供了幾個(gè)api來(lái)讓我們便捷地向數(shù)組中添加元素,比如說(shuō)push,unshift
push()是添加一個(gè)元素在數(shù)組的末尾,這里我們無(wú)需操作其他的元素,只需要this,length+=1即可
unshift()是在數(shù)組的頭部添加一個(gè)元素,我們看到的僅僅只要其表面數(shù)組的頭部增加了一個(gè)元素,其實(shí)底層數(shù)組的中的所有成員都需要向后移動(dòng),從尾到頭的順序,如下所示,其就會(huì)凸顯出性能差的特點(diǎn)。

舉個(gè)栗子??
我們下面寫個(gè)栗子來(lái)清晰得比較一下兩者所耗費(fèi)的時(shí)間,我們的unshift耗費(fèi)了0.24毫秒,push耗費(fèi)了0.8毫秒,當(dāng)然所耗費(fèi)的時(shí)間還是根據(jù)所移動(dòng)的元素?cái)?shù)量來(lái)以指數(shù)倍提高的。
function _shift() {
var arr = []
console.time('_shift')
for (let i = 0; i < 1000; i++) {
arr.unshift(1)
}
console.timeEnd('_shift')
}
_shift()
function _push() {
var arr = []
console.time('_push')
for (let i = 0; i < 1000; i++) {
arr.push(1)
}
console.timeEnd('_push')
}
_push()
非連續(xù)內(nèi)存問(wèn)題
除此之外我們都知道JS數(shù)組是可以在同一數(shù)組中存儲(chǔ)不同數(shù)據(jù)類型的數(shù)據(jù)的,所以就造成了JS的數(shù)組是否分配連續(xù)內(nèi)存,是要看我們的數(shù)組成員類型的,當(dāng)數(shù)組內(nèi)成員為同一類,則為連續(xù)內(nèi)存,當(dāng)數(shù)組成員存在數(shù)組,字符串,那么就會(huì)分配非連續(xù)的內(nèi)存,多個(gè)非連續(xù)內(nèi)存會(huì)形成一個(gè)鏈表,當(dāng)存儲(chǔ)數(shù)據(jù)數(shù)量級(jí)龐大的時(shí)候,就會(huì)造成效率低下的問(wèn)題。下面我們針對(duì)數(shù)組成員相同和數(shù)組成員不同進(jìn)行一次耗時(shí)比較,為了凸顯效果我將次數(shù)提高到了10的7次冪
function _diff() {
var arr = new Array(10000000)
arr.push({ name: "cxy" })
console.time('_diff')
for (let i = 0; i < 10000000; i++) {
arr[i] = i
}
console.timeEnd('_diff')
}
_diff()
function _same() {
var arr = new Array(10000000)
console.time('_same')
for (let i = 0; i < 10000000; i++) {
arr[i] = i
}
console.timeEnd('_same')
}
_same()
最后可以清楚地比較出兩者的差距,非連續(xù)內(nèi)存的數(shù)組操作耗時(shí)是連續(xù)內(nèi)存的數(shù)組的幾倍。
總結(jié)
到此這篇關(guān)于JS數(shù)組在內(nèi)存中的效率問(wèn)題的文章就介紹到這了,更多相關(guān)JS數(shù)組在內(nèi)存的效率內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
擴(kuò)展Bootstrap Tooltip插件使其可交互的方法
這篇文章主要介紹了擴(kuò)展Bootstrap Tooltip插件使其可交互的方法,結(jié)合實(shí)例形式分析了bootstrap擴(kuò)展tooltip插件的原理與具體操作技巧,需要的朋友可以參考下2016-11-11
JS基于遞歸實(shí)現(xiàn)網(wǎng)頁(yè)版計(jì)算器的方法分析
這篇文章主要介紹了JS基于遞歸實(shí)現(xiàn)網(wǎng)頁(yè)版計(jì)算器的方法,結(jié)合實(shí)例形式分析了javascript采用遞歸算法實(shí)現(xiàn)網(wǎng)頁(yè)版計(jì)算器的步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-12-12
JavaScript實(shí)現(xiàn)的in_array函數(shù)
這篇文章主要介紹了JavaScript實(shí)現(xiàn)的in_array函數(shù),用于判斷一個(gè)值是否在數(shù)組中,類似PHP的in_array函數(shù),需要的朋友可以參考下2014-08-08
js判斷文件類型大小并給出提示的實(shí)現(xiàn)方法
下面小編就為大家分享一篇js判斷文件類型大小并給出提示的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01
JavaScript必知必會(huì)(五) eval 的使用
這篇文章主要介紹了JavaScript必知必會(huì)(五) eval 的使用 的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06
JavaScript基于replace+正則實(shí)現(xiàn)ES6的字符串模版功能
這篇文章主要介紹了JavaScript基于replace+正則實(shí)現(xiàn)ES6的字符串模版功能,結(jié)合實(shí)例形式分析了replace結(jié)合正則實(shí)現(xiàn)ES6字符串模板功能的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-04-04
詳解JS實(shí)現(xiàn)簡(jiǎn)單的時(shí)分秒倒計(jì)時(shí)代碼
這篇文章主要介紹了JS時(shí)分秒倒計(jì)時(shí)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
webpack結(jié)合express實(shí)現(xiàn)自動(dòng)刷新的方法
這篇文章主要給大家介紹了關(guān)于webpack結(jié)合express實(shí)現(xiàn)自動(dòng)刷新的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用webpack具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
JavaScript實(shí)現(xiàn)異步獲取表單數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)異步獲取表單數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-05-05

