成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳談JavaScript數組合并常見幾大方法

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

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

詳談JavaScript數組合并常見幾大方法

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

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 ) );
    }
}

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

責任編輯:王雪燕 來源: 碼農網
相關推薦

2009-11-17 15:13:28

PHP數組

2018-07-04 05:51:04

弱電系統線路故障

2009-07-16 10:35:34

iBATIS特性

2009-11-17 15:57:26

PHP數組合并

2009-11-25 10:25:43

PHP數組合并與拆分

2010-08-12 11:12:27

Flex誤區

2011-02-18 09:34:10

SQLite

2009-11-16 17:27:56

PHP數組合并

2009-11-18 14:11:10

PHP數組變量

2010-10-08 16:11:06

Javascript數

2015-05-28 09:52:21

PHP判斷數組為空

2009-11-16 17:07:58

PHP二維數組

2017-12-05 10:11:32

機房監控內容

2009-08-28 11:43:26

C#數組初始化

2009-11-18 11:30:26

PHP數組排序

2011-06-08 15:31:43

JAVA多維數組

2016-10-13 19:33:10

javascript數組indexOf

2009-09-17 08:47:00

Linq查詢

2009-12-07 11:11:41

WCF返回值

2010-07-30 14:43:55

Flex應用
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久精品国产久精国产 | 欧美在线一区二区三区 | 99国产精品99久久久久久粉嫩 | 人人人干| 精产嫩模国品一二三区 | 日韩毛片| 国产福利精品一区 | 日美女逼逼 | 久久精品免费一区二区 | 久久国产视频网站 | 欧美精品久久久 | 国产激情精品一区二区三区 | 久久免费视频1 | 婷婷激情在线 | 免费精品一区 | 亚洲精品久久久蜜桃网站 | 91视频在线观看 | 在线中文字幕日韩 | 91精品国产综合久久久亚洲 | 精品欧美一区二区在线观看欧美熟 | 少妇精品久久久久久久久久 | 国产一区二区三区久久久久久久久 | 精品国产精品国产偷麻豆 | 欧美影院| 亚洲一区久久 | 国产乱码精品1区2区3区 | 丁香综合 | 国产精品一区久久久 | 黄色网址在线免费观看 | 久久免费国产 | 天天操天天操 | 四虎在线视频 | 一级在线观看 | 久久久久久久久久一区 | 日韩精品区 | 91传媒在线观看 | 97色在线视频 | 一区二区三区观看视频 | 欧美jizzhd精品欧美巨大免费 | av免费在线观看网站 | 久久蜜桃av一区二区天堂 |