1. <ul id="0c1fb"></ul>

      <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
      <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区

      RELATEED CONSULTING
      相關(guān)咨詢
      選擇下列產(chǎn)品馬上在線溝通
      服務(wù)時(shí)間:8:30-17:00
      你可能遇到了下面的問(wèn)題
      關(guān)閉右側(cè)工具欄

      新聞中心

      這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
      JavaScript中怎么實(shí)現(xiàn)數(shù)組合并操作

      本篇文章為大家展示了JavaScript中怎么實(shí)現(xiàn)數(shù)組合并操作,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

      成都創(chuàng)新互聯(lián)提供高防主機(jī)、云服務(wù)器、香港服務(wù)器、服務(wù)器托管

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

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

      上述內(nèi)容就是JavaScript中怎么實(shí)現(xiàn)數(shù)組合并操作,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


      文章題目:JavaScript中怎么實(shí)現(xiàn)數(shù)組合并操作
      標(biāo)題鏈接:http://ef60e0e.cn/article/ppggeh.html
      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区
      1. <ul id="0c1fb"></ul>

        <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
        <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

        肇庆市| 黄浦区| 滨海县| 桓台县| 务川| 麟游县| 隆尧县| 旺苍县| 汝阳县| 绥芬河市| 石狮市| 瑞安市| 神池县| 内江市| 信宜市| 阿拉善盟| 禄丰县| 怀化市| 北安市| 嘉祥县| 卓尼县| 文化| 邢台市| 宝应县| 当雄县| 泗洪县| 锡林浩特市| 广平县| 黄冈市| 于都县| 兴安县| 宣汉县| 涞源县| 张掖市| 沧州市| 汶上县| 分宜县| 垫江县| 贵溪市| 和田县| 丰县|