茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    JavaScript數(shù)組合并的多種方法
    來(lái)源:易賢網(wǎng) 閱讀:1313 次 日期:2016-06-25 11:58:32
    溫馨提示:易賢網(wǎng)小編為您整理了“JavaScript數(shù)組合并的多種方法”,方便廣大網(wǎng)友查閱!

    這篇文章主要為大家詳細(xì)介紹了JavaScript數(shù)組合并的多種方法,感興趣的朋友可以參考一下

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

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

    var a = [ 1, 2, 3, 4, 5, 6, 7, 8, 9 ];

    var b = [ "foo", "bar", "baz", "bam", "bun", "fun" ];

    很顯然最簡(jiǎn)單的結(jié)合結(jié)果應(yīng)該是:

    [

      1, 2, 3, 4, 5, 6, 7, 8, 9,

      "foo", "bar", "baz", "bam" "bun", "fun"

    ]

    concat(..)

    這是最常見(jiàn)的做法:

    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是一個(gè)全新的數(shù)組,表示a和b兩個(gè)數(shù)組的組合,并讓A和B不變。簡(jiǎn)單吧?

    但如果a有10,000個(gè)元素,而b也有一萬(wàn)個(gè)元素? C就會(huì)有2萬(wàn)個(gè)元素,所以a和b的內(nèi)內(nèi)存使用就會(huì)翻倍。

    “沒(méi)問(wèn)題!”,你說(shuō)。讓它們被垃圾回收,把A和B設(shè)置為null,問(wèn)題解決了!

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

    呵呵。對(duì)于只有幾個(gè)元素的小數(shù)組,這沒(méi)啥問(wèn)題。但對(duì)于大數(shù)組,或者在內(nèi)存有限的系統(tǒng)中需要經(jīng)常重復(fù)這個(gè)過(guò)程,它其實(shí)還有很多改進(jìn)的地方。

    循環(huán)插入

    好吧,讓我們將一個(gè)數(shù)組的內(nèi)容復(fù)制到另一個(gè),使用: 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的內(nèi)容。

    似乎有更好的內(nèi)存占用。

    但如果a數(shù)組比較小?出于內(nèi)存和速度的原因,你可能要把更小的a放到b的前面,。沒(méi)問(wèn)題,只需將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"]

    功能技巧

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

    這是我們的第一次嘗試,使用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(..)是不錯(cuò)的,但他們是一點(diǎn)點(diǎn)笨拙。 ES6=>的箭頭函數(shù)將減少一些代碼量,但它仍然需要一個(gè)函數(shù),每個(gè)元素都需要調(diào)用一次,不是很完美。

    那這個(gè)怎么樣:

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

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

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

    第一個(gè)主要的問(wèn)題是,內(nèi)存使用量增長(zhǎng)了一倍(當(dāng)然只是暫時(shí)的!)被追加內(nèi)容基本上是通過(guò)函數(shù)調(diào)用將元素復(fù)制到堆棧中。此外,不同的JS引擎都有拷貝數(shù)據(jù)長(zhǎng)度的限制。

    所以,如果數(shù)組有一百萬(wàn)個(gè)元素,你肯定會(huì)超出了push(…)或unshift(…)允許調(diào)用堆棧的限制。唉,處理幾千個(gè)元素它會(huì)做得很好,但你必須要小心,不能超過(guò)合理的長(zhǎng)度限值。

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

    有一種方法可以避免這種最大長(zhǎng)度限制。

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

      }

    }

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

    以上就是本文的全部?jī)?nèi)容,希望對(duì)大家學(xué)習(xí)javascript程序設(shè)計(jì)有所幫助。

    更多信息請(qǐng)查看網(wǎng)絡(luò)編程
    易賢網(wǎng)手機(jī)網(wǎng)站地址:JavaScript數(shù)組合并的多種方法
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢(xún)回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢(xún)?yōu)闇?zhǔn)!

    2026上岸·考公考編培訓(xùn)報(bào)班

    • 報(bào)班類(lèi)型
    • 姓名
    • 手機(jī)號(hào)
    • 驗(yàn)證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢(xún) | 簡(jiǎn)要咨詢(xún)須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
    工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
    云南網(wǎng)警備案專(zhuān)用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢(xún)關(guān)注公眾號(hào):hfpxwx
    咨詢(xún)QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)