日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

合并JavaScript數(shù)組的N種方法

瀏覽:166日期:2023-11-22 15:01:42

這是一篇簡單的文章,關于JavaScript數(shù)組使用的一些技巧。我們將使用不同的方法結合/合并兩個JS數(shù)組,以及討論每個方法的優(yōu)點/缺點。

讓我們先考慮下面這情況:

var a = [ 1, 2, 3, 4, 5, 6, 7, 8, 9 ];var b = [ "foo", "bar", "baz", "bam", "bun", "fun" ];

很顯然最簡單的結合結果應該是:

[ 1, 2, 3, 4, 5, 6, 7, 8, 9, "foo", "bar", "baz", "bam" "bun", "fun"]concat(..)

這是最常見的做法:

var c = a.concat( b );a; // [1,2,3,4,5,6,7,8,9]b; // ["foo","bar","baz","bam","bun","fun"]c; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]

正如你所看到的,C是一個全新的數(shù)組,表示a和b兩個數(shù)組的組合,并讓A和B不變。簡單吧?

但如果a有10,000個元素,而b也有一萬個元素? C就會有2萬個元素,所以a和b的內內存使用就會翻倍。

“沒問題!”,你說。讓它們被垃圾回收,把A和B設置為null,問題解決了!

a = b = null; // 'a'和'b'就被回收了

呵呵。對于只有幾個元素的小數(shù)組,這沒啥問題。但對于大數(shù)組,或者在內存有限的系統(tǒng)中需要經常重復這個過程,它其實還有很多改進的地方。

循環(huán)插入

好吧,讓我們將一個數(shù)組的內容復制到另一個,使用: Array#push(..)

// `b` onto `a`for (var i=0; i < b.length; i++) { a.push( b[i] );}a; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]b = null;

現(xiàn)在,數(shù)組a有了數(shù)組b的內容。

似乎有更好的內存占用。

但如果a數(shù)組比較小?出于內存和速度的原因,你可能要把更小的a放到b的前面,。沒問題,只需將push(..)換成unshift(..)即可:

// `a` into `b`:for (var i=a.length-1; i >= 0; i--) { b.unshift( a[i] );}b; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]功能技巧

不過for循環(huán)確實比較丑,而且不好維護。我們可以做的更好嗎?

這是我們的第一次嘗試,使用Array#reduce:

// `b` onto `a`:a = b.reduce( function(coll,item){ coll.push( item ); return coll;}, a );a; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]// or `a` into `b`:b = a.reduceRight( function(coll,item){ coll.unshift( item ); return coll;}, b );b; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]

Array#reduce(..) 和 Array#reduceRight(..)是不錯的,但他們是一點點笨拙。 ES6=>的箭頭函數(shù)將減少一些代碼量,但它仍然需要一個函數(shù),每個元素都需要調用一次,不是很完美。

那這個怎么樣:

// `b` onto `a`:

a.push.apply( a, b );

a; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]

// or `a` into `b`:

b.unshift.apply( b, a );

b; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]

這是一個要好很多吧?特別是因為 unshift(..)方法在這里并不需要擔心前面的反向排序。 ES6的spead操作會更漂亮: a.push( ...b ) 或 b.unshift( ...a

數(shù)組最大長度限制

第一個主要的問題是,內存使用量增長了一倍(當然只是暫時的!)被追加內容基本上是通過函數(shù)調用將元素復制到堆棧中。此外,不同的JS引擎都有拷貝數(shù)據(jù)長度的限制。

所以,如果數(shù)組有一百萬個元素,你肯定會超出了push(...)或unshift(...)允許調用堆棧的限制。唉,處理幾千個元素它會做得很好,但你必須要小心,不能超過合理的長度限值。

注意: 你可以嘗試一下splice(...),它跟push(...)和unshift(...)一樣都有這種問題。

有一種方法可以避免這種最大長度限制。

function combineInto(a,b) { var len = a.length; for (var i=0; i < len; i=i+5000) {b.unshift.apply( b, a.slice( i, i+5000 ) ); }}

等一下,我們的可讀性倒退了。 就這樣吧,可能會越改越差,呵。

原文地址: davidwalsh.name

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩1区| 日韩精品欧美成人高清一区二区| 91精品美女| 婷婷视频一区二区三区| 99视频精品免费观看| 欧美午夜不卡| 视频一区二区三区入口| 蜜桃视频第一区免费观看| 亚洲综合图色| 欧美专区一区| 国产极品一区| 麻豆视频在线看| 亚洲午夜电影| 蜜臀av一区二区三区| 日韩精品视频网站| 国产精品最新| 精品午夜视频| 国产99久久久国产精品成人免费| 91久久国产| 四虎精品永久免费| 日韩精品高清不卡| 国产精品国码视频| av中文资源在线资源免费观看| 久久国产电影| 一本综合精品| 欧美精品成人| 欧美日韩尤物久久| 午夜在线一区| 91精品国产自产在线丝袜啪| 精品国产网站| 亚洲精品小说| 国产亚洲精品美女久久| 亚洲女同av| 国产精品外国| 国产精品免费大片| 激情视频网站在线播放色| 欧美日韩国产亚洲一区| 奇米狠狠一区二区三区| 日本精品黄色| 香蕉精品999视频一区二区| 欧美日韩亚洲一区二区三区在线| 国产在线日韩精品| 国产偷自视频区视频一区二区| 日韩成人av影视| 精品视频网站| 先锋亚洲精品| 国产一区调教| 国产色综合网| 精品国产亚洲一区二区三区| 不卡视频在线| 91欧美精品| 亚洲涩涩在线| 日韩精品欧美大片| 欧美日一区二区| 91嫩草精品| 亚洲高清毛片| 国产精品对白| 中文日韩欧美| 亚洲综合电影| 奇米狠狠一区二区三区| 欧美色图一区| 久久精品伊人| 在线免费观看亚洲| 在线一区av| 亚洲精品美女91| 在线人成日本视频| 日韩激情网站| 国产专区一区| 精品国产一区二区三区2021| 亚洲欧美专区| 99视频精品全国免费| 麻豆成人91精品二区三区| 免费在线观看精品| 日韩精品欧美| 精品日韩一区| 97精品久久| 欧美中文日韩| 丝袜av一区| 美女av一区| 日韩高清欧美激情| 欧洲激情综合| 日韩欧美二区| 美腿丝袜在线亚洲一区| 色综合视频一区二区三区日韩 | 日本伊人午夜精品| 精品欧美一区二区三区在线观看| 欧美一级一区| 三级亚洲高清视频| 综合色一区二区| 精品国产一级| 蜜臀久久99精品久久久久久9| 精品国产一区二| 亚洲婷婷丁香| 午夜日韩福利| 欧美aa在线观看| 国内一区二区三区| 国产专区一区| 在线一区av| caoporn视频在线| 欧美黑人做爰爽爽爽| 婷婷成人av| 视频在线观看一区二区三区| 久久国产电影| 久久精品观看| 国产超碰精品| 国产一二在线播放| 国产aⅴ精品一区二区四区| 国产精品一页| 日韩毛片一区| 日韩精品a在线观看91| 爽好久久久欧美精品| 亚洲国产一区二区在线观看 | 亚洲aa在线| 视频一区国产视频| 亚洲欧美日本日韩| 国产精品美女久久久浪潮软件| 久久久久国产| 99精品网站| 久久亚洲国产| 久久精品二区三区| 99精品在线观看| 亚洲二区免费| 激情婷婷综合| 免费欧美一区| 欧美粗暴jizz性欧美20| 国产一区视频在线观看免费| 久久精品欧美一区| 亚洲精品a级片| 鲁大师影院一区二区三区| 日韩在线一区二区| 亚洲精品一区二区在线播放∴| 蜜桃传媒麻豆第一区在线观看| 丝袜亚洲另类欧美| 亚洲bt欧美bt精品777| 日韩av中文在线观看| 欧美日韩1区2区3区| 精品黄色一级片| 成人三级高清视频在线看| 日韩免费福利视频| 亚洲五月婷婷| 日韩在线播放一区二区| 亚洲男人在线| 麻豆久久一区| 亚洲成av在线| 好吊视频一区二区三区四区| 日韩中文字幕亚洲一区二区va在线| 中文字幕乱码亚洲无线精品一区| 亚洲日韩视频| 国产欧美视频在线| 你懂的亚洲视频| 在线天堂中文资源最新版| 亚洲午夜一级| 亚洲男人在线| 久久99性xxx老妇胖精品| 欧产日产国产精品视频| 中文一区在线| 欧美久久久网站| 一区二区精品伦理...| 亚洲欧美日韩高清在线| 亚洲ab电影| 成人午夜亚洲| 日韩视频二区| 国产欧美三级| 夜鲁夜鲁夜鲁视频在线播放| 国产综合视频| 日本精品久久| 成人av三级| 久久午夜精品| 免费精品一区| 好看不卡的中文字幕| 日韩av资源网| 美女网站视频一区| 午夜精品福利影院| 日韩88av| 美女精品在线观看| 精品国产午夜| 久久99伊人| 精品不卡一区| 亚洲色图综合| 荡女精品导航| 久久最新视频| 精品少妇一区| 亚洲一级大片| 中文在线а√在线8| 蜜臀久久99精品久久久画质超高清| 久久不见久久见中文字幕免费 | 国产精品蜜月aⅴ在线| 欧美日韩中文字幕一区二区三区| 日韩激情精品| 91久久国产| 久久影院一区二区三区| 国产一区91| 久久天堂影院| 亚洲欧美一级| 久久亚洲成人| 欧美1区2区3| 亚洲一二三区视频| 91精品一区国产高清在线gif| 久久国产日韩欧美精品| 国产精品88久久久久久|