亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

使用不同的方法結合/合并兩個JS數組

2019-11-20 14:07:31
字體:
來源:轉載
供稿:網友

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

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

復制代碼 代碼如下:

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是一個全新的數組,表示a和b兩個數組的組合,并讓A和B不變。簡單吧?

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

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

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

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

好吧,讓我們將一個數組的內容復制到另一個,使用: 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;
現在,數組a有了數組b的內容。

似乎有更好的內存占用。

但如果a數組比較?。砍鲇趦却婧退俣鹊脑?,你可能要把更小的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循環確實比較丑,而且不好維護。我們可以做的更好嗎?

這是我們的第一次嘗試,使用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=>的箭頭函數將減少一些代碼量,但它仍然需要一個函數,每個元素都需要調用一次,不是很完美。

那這個怎么樣:

復制代碼 代碼如下:

// `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

數組最大長度限制

第一個主要的問題是,內存使用量增長了一倍(當然只是暫時的?。┍蛔芳觾热莼旧鲜峭ㄟ^函數調用將元素復制到堆棧中。此外,不同的JS引擎都有拷貝數據長度的限制。

所以,如果數組有一百萬個元素,你肯定會超出了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 ) );
}
}
等一下,我們的可讀性倒退了。 就這樣吧,可能會越改越差,呵。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲免费福利视频| 中文字幕亚洲二区| 日韩免费观看网站| 日韩欧美精品网址| 国产精品一区电影| 亚洲欧洲激情在线| 美女精品视频一区| 97视频国产在线| 国产97色在线|日韩| 精品久久久国产精品999| 久久久久久尹人网香蕉| 亚洲色图欧美制服丝袜另类第一页| 欧美精品久久久久久久久| 国产日韩精品综合网站| 日韩av免费在线看| 在线播放日韩专区| 欧美极品美女电影一区| 亚洲欧美精品中文字幕在线| 国产一区二区丝袜高跟鞋图片| 欧美二区在线播放| 亚洲国内高清视频| 91tv亚洲精品香蕉国产一区7ujn| 一区二区福利视频| 久久久久国产精品www| 色偷偷88888欧美精品久久久| 国产精品免费一区二区三区都可以| 在线观看欧美www| 中文字幕欧美专区| 精品亚洲一区二区| 中文字幕亚洲二区| 精品国产一区二区三区久久| 人人澡人人澡人人看欧美| 国产ts一区二区| 国产精品99免视看9| 欧美成人精品一区二区三区| 三级精品视频久久久久| 国产成人avxxxxx在线看| 九九精品视频在线观看| 国产亚洲精品久久久久动| 91亚洲精品久久久| 日韩精品电影网| 日韩视频精品在线| 国产中文字幕日韩| 亚洲福利影片在线| 日韩极品精品视频免费观看| 亚洲美女视频网| 精品国产一区二区三区久久久| 日韩欧美国产免费播放| 欧美激情一区二区三级高清视频| 日韩a**中文字幕| 热久久这里只有精品| 91久久夜色精品国产网站| 92福利视频午夜1000合集在线观看| 国产一区二区视频在线观看| 日韩欧美中文字幕在线播放| 成人亚洲欧美一区二区三区| 亚洲少妇激情视频| 精品久久久久久久久中文字幕| 日韩中文在线观看| 色偷偷888欧美精品久久久| 98视频在线噜噜噜国产| 日产精品99久久久久久| 欧美日韩国产成人高清视频| 日韩有码在线视频| 亚洲男人天堂手机在线| 欧美激情a∨在线视频播放| 欧美最猛黑人xxxx黑人猛叫黄| 宅男66日本亚洲欧美视频| 久久综合免费视频影院| 亚洲夜晚福利在线观看| 国产精品91在线| 欧美激情在线有限公司| 久久久久久久久久婷婷| 国产精品自产拍在线观| 欧美激情手机在线视频| 成人黄色影片在线| 色中色综合影院手机版在线观看| 欧美激情2020午夜免费观看| 亚洲第一精品夜夜躁人人躁| 欧美日韩在线另类| 欧美性猛交99久久久久99按摩| 国产精品中文字幕在线| 欧美放荡办公室videos4k| 国产精品99久久久久久久久久久久| 欧美性受xxxx白人性爽| 精品亚洲永久免费精品| 亚洲精品资源美女情侣酒店| 亚洲精品日产aⅴ| 91免费精品国偷自产在线| 亚洲成人亚洲激情| 国内精久久久久久久久久人| 色偷偷噜噜噜亚洲男人的天堂| 91高清视频在线免费观看| 亚洲成年人在线| 97久久精品人搡人人玩| 欧美日韩综合视频网址| 欧美激情按摩在线| 91精品国产高清久久久久久| 丝袜情趣国产精品| 91色p视频在线| 欧美日韩一区免费| 国产一区二区三区视频免费| 色综合久久中文字幕综合网小说| 欧美精品情趣视频| 欧美激情精品久久久久久| 国产成人精品优优av| 国产精品成人在线| 正在播放欧美一区| 亚洲mm色国产网站| 久久国产一区二区三区| 国产精品网站入口| 亚洲第一免费网站| 国产亚洲精品激情久久| 国产精品96久久久久久又黄又硬| 国产精品草莓在线免费观看| 日韩中文娱乐网| 亚洲一级黄色片| 高清一区二区三区四区五区| 懂色aⅴ精品一区二区三区蜜月| 26uuu亚洲国产精品| 精品国产区一区二区三区在线观看| 午夜精品福利电影| 国产美女久久精品| 日韩视频免费看| 欧美肥老太性生活视频| 亚洲免费伊人电影在线观看av| 成人福利视频网| 亚洲欧洲自拍偷拍| 欧美在线不卡区| 夜夜嗨av色综合久久久综合网| 国产69精品久久久久99| 欧美理论片在线观看| 91av网站在线播放| 欧美丝袜一区二区三区| 久久久欧美精品| 国产成人福利夜色影视| 久久久久久免费精品| 欧美性少妇18aaaa视频| 国产精品jizz在线观看麻豆| 91中文字幕一区| 欧美日韩亚洲激情| 国产精品高潮粉嫩av| 日韩电影中文字幕av| xvideos成人免费中文版| 国产精品久久久久久久久久尿| 日本国产欧美一区二区三区| 日韩av在线精品| 精品亚洲男同gayvideo网站| 成人h视频在线| 国产欧美精品一区二区三区-老狼| 成人免费高清完整版在线观看| 日韩成人性视频| 亚洲伊人久久大香线蕉av| 亚洲精品欧美极品| 亚洲电影免费观看| 国内久久久精品| 日韩电影中文字幕av| 色噜噜狠狠狠综合曰曰曰88av| 欧美激情精品久久久久久| 久久艹在线视频| 91大神在线播放精品| 日韩成人中文字幕| 精品国内亚洲在观看18黄| 夜夜嗨av色综合久久久综合网|