中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JS數組在內存中效率問題的示例分析

發布時間:2022-02-20 16:55:49 來源:億速云 閱讀:148 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關JS數組在內存中效率問題的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

JS數組

我們所熟知的JS數組的結構和其他語言數組結構類似,即物理內存是連續的,所以這也就導致了數組成員移動次數越少,其效率越高,一般數組會被分配到一段連續的內存中,像這樣

JS數組在內存中效率問題的示例分析

大家可能會疑問,你為啥要給畫一個邊框呢,其實我們的數組在定義的時候默認了它的長度,即當我們像要在數組中添加元素的時候,就需要對它的長度做出改變。

效率比較

JS提供了幾個api來讓我們便捷地向數組中添加元素,比如說push,unshift

  • push()是添加一個元素在數組的末尾,這里我們無需操作其他的元素,只需要this,length+=1即可

  • unshift()是在數組的頭部添加一個元素,我們看到的僅僅只要其表面數組的頭部增加了一個元素,其實底層數組的中的所有成員都需要向后移動,從尾到頭的順序,如下所示,其就會凸顯出性能差的特點。

JS數組在內存中效率問題的示例分析

舉個栗子????

我們下面寫個栗子來清晰得比較一下兩者所耗費的時間,我們的unshift耗費了0.24毫秒,push耗費了0.8毫秒,當然所耗費的時間還是根據所移動的元素數量來以指數倍提高的。

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()

JS數組在內存中效率問題的示例分析

非連續內存問題

除此之外我們都知道JS數組是可以在同一數組中存儲不同數據類型的數據的,所以就造成了JS的數組是否分配連續內存,是要看我們的數組成員類型的,當數組內成員為同一類,則為連續內存,當數組成員存在數組,字符串,那么就會分配非連續的內存,多個非連續內存會形成一個鏈表,當存儲數據數量級龐大的時候,就會造成效率低下的問題。下面我們針對數組成員相同和數組成員不同進行一次耗時比較,為了凸顯效果我將次數提高到了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()

JS數組在內存中效率問題的示例分析

最后可以清楚地比較出兩者的差距,非連續內存的數組操作耗時是連續內存的數組的幾倍。

感謝各位的閱讀!關于“JS數組在內存中效率問題的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

js
AI

清原| 尚义县| 肃宁县| 文登市| 邯郸县| 华阴市| 榆中县| 南投县| 思南县| 昌乐县| 东平县| 博湖县| 博兴县| 东港市| 兴文县| 大兴区| 桂平市| 平利县| 阿克陶县| 秭归县| 雅江县| 深水埗区| 罗城| 四子王旗| 南澳县| 绥阳县| 景洪市| 鲁甸县| 屯昌县| 治县。| 奉新县| 松江区| 宁化县| 开封市| 公主岭市| 曲沃县| 精河县| 巴塘县| 溧阳市| 壶关县| 潜江市|