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

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 16:08:57
字體:
來源:轉載
供稿:網友
 

這是一篇簡單的文章,關于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
色老头一区二区三区在线观看| 久久夜精品香蕉| 国产在线日韩在线| 欧美乱大交做爰xxxⅹ性3| 久久精品中文字幕电影| 97在线观看视频国产| 日韩在线中文字| 亚洲欧洲高清在线| 91在线观看欧美日韩| 日韩大陆毛片av| 亚洲开心激情网| 北条麻妃99精品青青久久| 欧美在线视频免费播放| 亚洲欧美成人精品| 亚洲天堂一区二区三区| 国产日韩av在线播放| 日本一区二区在线播放| 亚洲国产精品va在线看黑人| 成人精品久久av网站| 亚洲视频电影图片偷拍一区| 欧美激情三级免费| 97视频在线看| 亚洲国产精品va在看黑人| 国产日韩欧美综合| 国产xxx69麻豆国语对白| 国产91精品久| 97色在线播放视频| 麻豆国产va免费精品高清在线| 1769国内精品视频在线播放| 92看片淫黄大片看国产片| 91久久国产婷婷一区二区| 性欧美暴力猛交69hd| 性欧美在线看片a免费观看| 一区二区在线视频播放| 国产精品偷伦视频免费观看国产| 国产亚洲精品va在线观看| 国产精品久久久久久亚洲影视| 亚洲第一中文字幕在线观看| 亚洲缚视频在线观看| 欧美国产视频一区二区| 亚洲欧美制服丝袜| 欧美国产日韩一区二区| 992tv成人免费视频| 成人www视频在线观看| 欧美又大又粗又长| …久久精品99久久香蕉国产| 亚洲精品美女在线| 日韩最新在线视频| 2018中文字幕一区二区三区| 亚洲免费电影在线观看| 久久天堂av综合合色| 久热精品视频在线免费观看| 久久久99久久精品女同性| 欧美国产日韩免费| 国产亚洲欧美另类中文| 国产精品久久久久久久久久久不卡| 成人a视频在线观看| 国产精品91在线观看| 国产精品久久在线观看| 亚洲视频在线观看网站| 亚洲无线码在线一区观看| 午夜精品一区二区三区av| 97在线视频国产| 欧美精品在线观看91| 国产91在线播放| 国产精品中文字幕久久久| 欧美成人激情视频免费观看| 精品日本高清在线播放| 2018国产精品视频| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲福利精品在线| 91日本在线观看| 欧美日韩视频在线| 欧美大尺度在线观看| 91欧美日韩一区| 国产精品久久久久久久久久尿| 国产精品久久中文| 成人激情在线观看| 91免费人成网站在线观看18| 高清欧美一区二区三区| 久久亚洲精品小早川怜子66| 一本一本久久a久久精品综合小说| 黑人欧美xxxx| 亚洲精品成人久久久| 中文字幕av一区中文字幕天堂| 国产精品电影久久久久电影网| 好吊成人免视频| 96精品久久久久中文字幕| 中文字幕日本精品| 97在线看免费观看视频在线观看| 亚洲成色777777在线观看影院| 77777少妇光屁股久久一区| 亚洲精品黄网在线观看| 欧美寡妇偷汉性猛交| 国产亚洲一级高清| 亚洲人av在线影院| 亚洲国产精品一区二区久| 亚洲精品在线91| 久久久97精品| 中文字幕在线日韩| 91免费在线视频网站| 黑人巨大精品欧美一区二区一视频| 日韩美女视频免费在线观看| 欧美国产第二页| 中文字幕欧美国内| 日韩免费观看在线观看| 成人在线播放av| 欧美麻豆久久久久久中文| 岛国av一区二区在线在线观看| 九九精品视频在线观看| 国产精品高潮在线| 欧美精品videossex性护士| 欧美视频国产精品| 欧美国产日韩一区二区在线观看| 国产视频亚洲精品| 国产91精品久久久久久久| 亚洲黄色成人网| 精品视频在线播放免| 亚洲最大激情中文字幕| 亚洲精品国精品久久99热| 国产在线观看91精品一区| 少妇高潮 亚洲精品| 狠狠躁夜夜躁人人爽超碰91| 国产精品久久久久久av| 久久久久99精品久久久久| 久久精品国产99国产精品澳门| 日韩欧美视频一区二区三区| 欧美久久久精品| 欧美洲成人男女午夜视频| 97在线精品国自产拍中文| 欧美日韩国产中文精品字幕自在自线| 欧美日韩xxxxx| 日韩精品丝袜在线| 国产精品成人国产乱一区| 日韩免费观看在线观看| 色偷偷偷综合中文字幕;dd| 日韩在线免费视频| 国产精品日韩在线一区| 国产在线视频不卡| 日韩视频―中文字幕| 超碰日本道色综合久久综合| 欧美成人剧情片在线观看| 午夜精品一区二区三区在线| 国内精品小视频在线观看| 91精品国产99久久久久久| 亚洲美腿欧美激情另类| 欧美激情亚洲综合一区| 国产精品欧美一区二区三区奶水| 国产丝袜精品视频| 国产精品尤物福利片在线观看| 尤物99国产成人精品视频| 不用播放器成人网| 国内成人精品视频| 亚洲欧美日韩久久久久久| 91高潮精品免费porn| 在线精品高清中文字幕| 狠狠躁天天躁日日躁欧美| 欧美成人中文字幕| 国产精品视频内| 日韩电影第一页| 国产噜噜噜噜噜久久久久久久久| 中文字幕亚洲无线码在线一区| 91影视免费在线观看| 欧美极品少妇全裸体|