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

首頁 > 語言 > JavaScript > 正文

JS合并數組的幾種方法及優劣比較

2024-05-06 16:08:59
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了JS合并數組的幾種方法及優劣比較,本文講解了concat、循環插入、reduce等方法合并數組,并對它們的優劣做了比較,需要的朋友可以參考下
 
 

本文屬于JavaScript的基礎技能. 我們將學習結合/合并兩個JS數組的各種常用方法,并比較各種方法的優缺點.

我們先來看看具體的場景:

 

復制代碼代碼如下:

var q = [ 5, 5, 1, 9, 9, 6, 4, 5, 8];
var b = [ "tie", "mao", "csdn", "ren", "fu", "fei" ];

 

很明顯,數組 q 和 b 簡單拼接的結果是:

復制代碼代碼如下:

[
    5, 5, 1, 9, 9, 6, 4, 5, 8, 
    "tie", "mao", "csdn", "ren", "fu", "fei"
]

 

concat(..)方法

最常見的用法如下:

復制代碼代碼如下:

var c = q.concat( b );

 

q; // [5,5,1,9,9,6,4,5,8]
b; // ["tie","mao","csdn","ren","fu","fei"];

c; // [5,5,1,9,9,6,4,5,8,"tie","mao","csdn","ren","fu","fei"]

 

如您所見, c 是一個全新的數組, 表示 q 和 b 這兩個數組的組合, 但是 q 和 b 現在沒用了是吧?

如果 q 數組有10000個元素, b 數組也有有10000個元素? 那么數組c現在就有20000個元素, 這種方式占用了2倍的內存.

“這沒問題!”,你可能會覺得. 只要將 q 和 b 置空就行, 然后就會被垃圾回收,對嗎?問題解決了!

復制代碼代碼如下:

q = b = null; // `q` and `b` 現在可以被垃圾回收了

 

額? 如果數組都很小,那自然沒問題. 但對大型的數組,或需要多次重復處理時, 內存就被限制了, 它還需要進行優化.

循環插入

OK, 讓我們把一個數組的內容加入到另一個中試試,使用 Array#push() 方法:

復制代碼代碼如下:

// 將數組 `b` 插入 `q`
for (var i=0; i < b.length; i++) {
    q.push( b[i] );
}

 

q; // [5,5,1,9,9,6,4,5,8,"tie","mao","csdn","ren","fu","fei"]

b = null;

 

現在, q中存放了兩個原始數組的內容(q + b).

看樣子對內存優化做的不錯.

但如果 q 數組很小而 b 又很大呢? 出于內存和速度的考慮,這時想把較小的 q 插入到 b 前面. 沒問題,只要用 unshift() 方法代替 push() 即可, 對應的也要從大到小進行循環遍歷:

復制代碼代碼如下:

// `q` into `b`:
for (var i=q.length-1; i >= 0; i--) {
    b.unshift( q[i] );
}

 

b; // [5,5,1,9,9,6,4,5,8,"tie","mao","csdn","ren","fu","fei"]

q = null;

 

實用技巧

悲催的是,for循環很土并且難以維護. 我們能做得更好嗎?
我們先試試 Array#reduce :

復制代碼代碼如下:

// `b` onto `q`:
q = b.reduce( function(coll,item){
    coll.push( item );
    return coll;
}, q );

 

q; // [5,5,1,9,9,6,4,5,8,"tie","mao","csdn","ren","fu","fei"]

// or `q` into `b`:
b = q.reduceRight( function(coll,item){
    coll.unshift( item );
    return coll;
}, b );

b; // [5,5,1,9,9,6,4,5,8,"tie","mao","csdn","ren","fu","fei"]

 

Array#reduce() 和 Array#reduceRight() 很高大上,但有點笨重,而且一般人也記不住.  JS規范6 中的 => 箭頭函數(arrow-functions) 能讓代碼量大大減少, 但需要對每個數組元素執行函數調用, 也是很渣的手段. 
那么下面的代碼怎么樣呢?

復制代碼代碼如下:

// `b` onto `q`:
q.push.apply( q, b );

 

q; // [5,5,1,9,9,6,4,5,8,"tie","mao","csdn","ren","fu","fei"]

// or `q` into `b`:
b.unshift.apply( b, q );

b; // [5,5,1,9,9,6,4,5,8,"tie","mao","csdn","ren","fu","fei"]

 

BIG更高了,是吧!? 特別是 unshift() 方法不需要像前面那樣考慮相反的順序. ES6 的展開運算符(spread operator, 加 ... 前綴)就更高端了: a.push( ...b ) 或者 b.unshift( ...a )

但是,事實上這種方法還是太樂觀了. 在這兩種情況下,不管是將 a 或 b 傳遞給 apply() 作為第二個參數(apply方式調用Function時第一個參數在內部變成this,即context,上下文,作用域), 還是使用 ... 展開運算符的方式, 實際上數組都會被打散成為函數的 arguments .
第一個主要的問題是,占用了雙倍的內存(當然,是臨時的!),因為需要將數組復制到函數棧之中. 此外,不同的JS引擎有不同的實現算法,可能會限制了函數可以傳遞的參數數量.

如果數組添加了一百萬個元素, 那一定會超過函數棧所允許的大小, 不管是push() 或 unshift()調用. 這種方式只在幾千個元素時可用,所以必須限制其不能超過一定范圍.

注意: 你也可以試試 splice(), 肯定會發現他和 push(..)/unshift(..) 都是一樣的限制.

一種選擇是繼續使用這種方法,但是采用分批次處理:

復制代碼代碼如下:

function combineInto(q,b) {
    var len = q.length;
    for (var i=0; i < len; i=i+5000) {
        // 一次處理5000條
        b.unshift.apply( b, q.slice( i, i+5000 ) );
    }
}

 

等等,我們損害了代碼的可讀性(甚至是性能!). 在我們放棄之前結束這個旅程吧.

總結

Array#concat() 是久經考驗的方法, 用于組合兩個(或多個)數組. 但他創建了一個新的數組,而不是修改現有的一個.

有很多變通的手法,但他們都有不同的優缺點,需要根據實際情況來選擇.

上面列出了各種 優點/缺點,也許最好的(包括沒有列出的)方法是 reduce(..) 和 reduceRight(..)

無論你選擇什么,都應該批判性地思考你的數組合并策略,而不是把它當作理所當然的事情. 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩美女在线观看| 亚洲精品日韩丝袜精品| 福利一区福利二区微拍刺激| 久久精品久久久久久国产 免费| 国模吧一区二区三区| 亲爱的老师9免费观看全集电视剧| www.美女亚洲精品| 中文字幕v亚洲ⅴv天堂| 亚洲成人1234| 国产欧美va欧美va香蕉在| 国产亚洲精品久久久久久777| 日本欧美爱爱爱| 亚洲国产福利在线| 久久影院模特热| 亚洲欧美综合精品久久成人| 日本精品va在线观看| 国产精品一区久久| 91天堂在线视频| 91爱视频在线| 亚洲xxxx妇黄裸体| 国产精品xxxxx| 俺去了亚洲欧美日韩| 国产精品吹潮在线观看| 日韩毛片中文字幕| 一区二区三区视频免费| 欧美成人激情视频免费观看| 国产小视频国产精品| 久久精品电影一区二区| 在线播放国产一区二区三区| 国产欧美精品一区二区| 国产精品日韩在线播放| 中日韩美女免费视频网址在线观看| 在线播放日韩欧美| 激情成人中文字幕| 欧美极品美女电影一区| 色综合久综合久久综合久鬼88| 亚洲人高潮女人毛茸茸| 一区二区三区视频免费| 欧美性生交大片免网| 精品中文字幕乱| 95av在线视频| 97在线视频免费播放| 日本aⅴ大伊香蕉精品视频| 欧美午夜精品在线| 亚洲欧美日韩国产精品| 国产精品久久久久久网站| 色悠久久久久综合先锋影音下载| 91老司机精品视频| 国产精品第三页| 国产精品久久久久久久久久尿| 久热99视频在线观看| 精品五月天久久| 亚洲少妇激情视频| 国产日韩欧美日韩| 亚洲国产成人一区| 在线丨暗呦小u女国产精品| 色琪琪综合男人的天堂aⅴ视频| 国产精品扒开腿爽爽爽视频| 97在线视频免费播放| 久久久精品在线| 日韩在线国产精品| 日韩在线观看精品| 成人午夜激情免费视频| 国产精品免费一区二区三区都可以| 在线观看精品国产视频| 成人av在线天堂| 国产精品美女在线| 一区二区三区四区精品| 亚洲精品久久7777777| 成人情趣片在线观看免费| 亚洲精品在线视频| 欧美日韩亚洲高清| 大胆人体色综合| 欧美精品激情视频| 国产精品视频网站| 麻豆国产精品va在线观看不卡| 亚洲一区二区三区久久| 国产午夜精品免费一区二区三区| 亚洲男人av在线| 91丨九色丨国产在线| 69久久夜色精品国产69乱青草| 欧美日在线观看| 国产精品黄色影片导航在线观看| 久久久久久国产精品三级玉女聊斋| 亚洲国产婷婷香蕉久久久久久| 97精品国产97久久久久久免费| 日韩精品中文字幕久久臀| 欧美成人精品不卡视频在线观看| 91免费在线视频网站| 亚洲欧洲日产国码av系列天堂| 国产精品国内视频| 国内精品久久久久久中文字幕| 欧美另类高清videos| 欧美性猛交xxxx免费看| 日韩精品久久久久久福利| 久久久久久久久久久亚洲| 亚洲天堂网在线观看| 国产日韩在线免费| 亚洲色图国产精品| 一区二区亚洲精品国产| 97色在线播放视频| 88国产精品欧美一区二区三区| 欧美成人午夜激情视频| 久久久精品中文字幕| 国产精品视频26uuu| 欧美电影免费观看高清| 欧亚精品在线观看| 亚洲欧美自拍一区| 日韩中文字幕欧美| 97在线精品国自产拍中文| 自拍视频国产精品| 国产69久久精品成人| 亚洲的天堂在线中文字幕| 最近2019中文字幕大全第二页| 久久久久久久久久av| 亚洲精品福利在线| 51午夜精品视频| 国产精品你懂得| 精品一区二区三区四区在线| 欧美性xxxxxxxxx| 91精品视频免费看| 日韩av免费在线看| 欧美日韩在线视频首页| 成人福利视频在线观看| 亚洲精品福利免费在线观看| 91精品国产91久久久久久不卡| 尤物精品国产第一福利三区| 久久国产色av| 国产欧美日韩亚洲精品| 96sao精品视频在线观看| 国产精品美女视频网站| 亚洲女在线观看| 国产日韩中文字幕在线| 国产精品91久久| 欧洲永久精品大片ww免费漫画| 91国产一区在线| 久久久999国产| 亚洲女同性videos| 成人在线中文字幕| 国产精品 欧美在线| 久久久欧美一区二区| 国语自产精品视频在线看一大j8| 国产亚洲美女精品久久久| 中文字幕精品在线视频| 国产一区二区视频在线观看| 成人乱色短篇合集| 韩剧1988在线观看免费完整版| 日韩大陆毛片av| 亚洲色图五月天| 91久久嫩草影院一区二区| 欧美孕妇毛茸茸xxxx| 北条麻妃一区二区三区中文字幕| 亚洲第一男人天堂| 人体精品一二三区| 国产亚洲a∨片在线观看| 欧美日韩国产精品一区二区三区四区| 日韩在线观看电影| 日韩欧美一区二区三区| 欧美激情一级二级| 亚洲国产99精品国自产| 国内精品久久久久久| 欧美电影在线观看| 亚洲人成电影网站色www| 成人网在线观看|