javascript數組去重3種方法的效能測試與比較

來源:互聯網
上載者:User

昨天參加的一個前端面試,其中有一題數組去重,首先想到的是對象存索引值的方法,代碼如下
方法一:(簡單存索引值) 複製代碼 代碼如下:Array.prototype.distinct1 = function() {
var i=0,tmp={},that=this.slice(0)
this.length=0;
for(;i<that.length;i++){
if(!(that[i] in tmp)){
this[this.length]=that[i];
tmp[that[i]]=true;
}
}
return this;
};

上面的方法不複雜,思路也簡單,可是遇到不同類型又能轉換成同樣的字串的就完了,比如1和"1";於是又用了傳統的雙重迴圈,代碼如下
方法二:(雙重迴圈) 複製代碼 代碼如下:Array.prototype.distinct2 = function() {
var i=0,flag,that=this.slice(0);
this.length=0;
for(;i<that.length;i++){
var tmp=that[i];
flag=true;
for(var j=0;j<this.length;j++){
if(this[j]===tmp){flag=false;break}
}
if(flag)this[this.length]=tmp;
}
return this;
};

上面這種方法得到了想要的結果,但是兩層迴圈效率比較低,我們再想辦法從第一種方法上上手,然後加上用字串來儲存數組項的類型,有新類型就連接字串加上去,尋找的時候就發現一個有儲存的類型就把存的類型的字串替換為空白,代碼如下
方法三:(存索引值和類型)
複製代碼 代碼如下:Array.prototype.distinct4 = function() {
var i=0,tmp={},t2,that=this.slice(0),one;
this.length=0;
for(;i<that.length;i++){
one=that[i];
t2=typeof one;
if(!(one in tmp)){
this[this.length]=one;
tmp[one]=t2;
}else if(tmp[one].indexOf(t2)==-1){
this[this.length]=one;
tmp[one]+=t2;
}
}
return this;
};

為了區別下不同資料的各種演算法的效率差距,取幾種極端的例子來驗證下,首先看看1-80全部數組項都不一樣迴圈1000次的情況,好吧,IE6弱爆了

IE9:Chrome:
Firefox:
IE6:

下面是80項全部重複的迴圈1000次的情況,綜合上面的資料一起發現除了IE6-8其它瀏覽器的雙重迴圈表現都不錯,而IE6-8雙重迴圈要慢10-20倍左右,悲催啊。如果你的網站只支援IE9以上的就可以放心用雙迴圈的方法了,否則還是使用健值的方法,根據資料的情況選擇使用方法一或方法三(圖中的方法四,才發現來不及改圖,原來的方法三是用了Array的indexOf,因為速度慢且不相容就沒放出來了)

IE9: Chrome:
Firefox: IE6:

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.