麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

從數(shù)據(jù)結構的角度分析 for each in 比 for in 快的多

2019-11-20 22:33:41
字體:
來源:轉載
供稿:網(wǎng)友

之前聽說火狐的JS引擎支持for each in的語法,例如下述的代碼:

復制代碼 代碼如下:

var arr = [10,20,30,40,50];
for each(var k in arr)
console.log(k);

  即可直接遍歷出arr數(shù)組的內容。

  由于只有FireFox才支持,所以幾乎所有的JS代碼都不用這一特征。

  不過在ActionScript里天生就支持for each的語法,不論Array還是Vector,還是Dictionary,只要是可枚舉的對象都可以for in和for each in。

  之前并沒有感覺有太大的差異,為了懶得敲一個each單詞,一直用熟悉的for in來遍歷。

  不過今天仔細琢磨了會,從數(shù)據(jù)結構的角度分析了下,覺得for in和for each in效率上有著本質的區(qū)別,無論是JS還是AS。

  原因很簡單:Array不是真正意義上的數(shù)組!

  何為真正意義的數(shù)組?當然就是傳統(tǒng)語言里type[]定義的數(shù)據(jù)類型,所有元素都是連續(xù)保存的。

  “Array”雖然也是數(shù)組的意思,但熟悉JS的都知道,它其實是個非線性的偽數(shù)組,下標可以是任意數(shù)字。寫入arr[1000000]并非真正申請容納一百萬個元素的空間,而是把1000000轉換成相應的哈希值,對應到很小一塊儲存空間里,從而節(jié)省了大量內存。
  例如有如下數(shù)組:

復制代碼 代碼如下:

var arr = [];
  arr[10] = 1000;
  arr[20] = 2000;
  arr[30] = 5000;
  arr[40] = 8000;
  arr[200] = 9000;

用for...in遍歷Array,是個很累贅的過程:

遍歷時每次訪問arr[k],都要進行一次Hash(k)計算,根據(jù)散列表的容量取模,如果存在沖突還得尋找最終的值結果。

如果支持for each...in的語法,其內部的數(shù)據(jù)結構就決定了會快很多:

Array里直接把每個values作為節(jié)點,通過鏈表關聯(lián)起來維護。每當有值添加或刪除,就更新其鏈接關系。
當for each...in遍歷時,只需從第一個節(jié)點往后迭代即可,無需任何Hash計算。

當然,對于AS3里Vector這樣的線性數(shù)組來說,兩者相差不大;同理,HTML5里支持二進制的數(shù)組ArrayBuffer也是如此。不過從理論上來看,即使arr是個連續(xù)的線性數(shù)組,for each in還是要快一點:

for...in遍歷時,每次訪問arr[k]都要進行下標越界檢查;而for each in則根據(jù)內部鏈表,直接從底層反饋出迭代變量,節(jié)省了越界檢查的過程。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产色视频在线观看免费 | 久久久成人动漫 | 国产亚洲精品精 | 一级裸体视频 | 毛片在线视频观看 | 毛片福利| 黄色高清av | 97中文字幕第一一一页 | 成人不卡在线观看 | 亚洲免费毛片基地 | 天天夜夜操操 | 美女网站色免费 | 免费一级毛片在线播放不收费 | 91av网址 | 欧美a久久| www.99xxxx.com| 欧洲精品久久久久69精品 | 久草视频手机在线观看 | 一区二区三区四区高清视频 | 色诱亚洲精品久久久久久 | 黄色片网站在线看 | 99国产精品自拍 | 蜜桃成品人免费视频 | 午夜视频在线看 | 嫩呦国产一区二区三区av | 黄色片网站在线免费观看 | chinese中国真实乱对白 | 久久成人午夜视频 | 九九热这里只有精品8 | 在线看免费观看日本 | 中文字幕免费一区 | 亚洲国产网站 | 鲁久久| 亚洲成人午夜精品 | 亚洲性生活视频 | 日本aⅴ在线 | 欧美一级理论 | 黄色影院在线看 | 神马久久精品综合 | 午夜视频大全 | 特片网久久 |