javascript數(shù)組去重3種方法的性能測(cè)試與比較
更新時(shí)間:2013年03月26日 11:40:44 作者:
面試題中有一題數(shù)組去重,首先想到的是對(duì)象存鍵值的方法可是遇到不同類型又能轉(zhuǎn)換成同樣的字符串的就完了接下來(lái)為大家介紹下雙重循環(huán)/存鍵值和類型實(shí)現(xiàn)去重,感興趣的各位可以參考下哈
昨天參加的一個(gè)前端面試,其中有一題數(shù)組去重,首先想到的是對(duì)象存鍵值的方法,代碼如下
方法一:(簡(jiǎn)單存鍵值)
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;
};
上面的方法不復(fù)雜,思路也簡(jiǎn)單,可是遇到不同類型又能轉(zhuǎn)換成同樣的字符串的就完了,比如1和"1";于是又用了傳統(tǒng)的雙重循環(huán),代碼如下
方法二:(雙重循環(huán))
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;
};
上面這種方法得到了想要的結(jié)果,但是兩層循環(huán)效率比較低,我們?cè)傧朕k法從第一種方法上上手,然后加上用字符串來(lái)保存數(shù)組項(xiàng)的類型,有新類型就連接字符串加上去,查找的時(shí)候就發(fā)現(xiàn)一個(gè)有保存的類型就把存的類型的字符串替換為空,代碼如下
方法三:(存鍵值和類型)
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;
};
為了區(qū)別下不同數(shù)據(jù)的各種算法的效率差距,取幾種極端的例子來(lái)驗(yàn)證下,首先看看1-80全部數(shù)組項(xiàng)都不一樣循環(huán)1000次的情況,好吧,IE6弱爆了
下面是80項(xiàng)全部重復(fù)的循環(huán)1000次的情況,綜合上面的數(shù)據(jù)一起發(fā)現(xiàn)除了IE6-8其它瀏覽器的雙重循環(huán)表現(xiàn)都不錯(cuò),而IE6-8雙重循環(huán)要慢10-20倍左右,悲催啊。如果你的網(wǎng)站只支持IE9以上的就可以放心用雙循環(huán)的方法了,否則還是使用健值的方法,根據(jù)數(shù)據(jù)的情況選擇使用方法一或方法三(圖中的方法四,才發(fā)現(xiàn)來(lái)不及改圖,原來(lái)的方法三是用了Array的indexOf,因?yàn)樗俣嚷也患嫒菥蜎](méi)放出來(lái)了)
方法一:(簡(jiǎn)單存鍵值)
復(fù)制代碼 代碼如下:
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;
};
上面的方法不復(fù)雜,思路也簡(jiǎn)單,可是遇到不同類型又能轉(zhuǎn)換成同樣的字符串的就完了,比如1和"1";于是又用了傳統(tǒng)的雙重循環(huán),代碼如下
方法二:(雙重循環(huán))
復(fù)制代碼 代碼如下:
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;
};
上面這種方法得到了想要的結(jié)果,但是兩層循環(huán)效率比較低,我們?cè)傧朕k法從第一種方法上上手,然后加上用字符串來(lái)保存數(shù)組項(xiàng)的類型,有新類型就連接字符串加上去,查找的時(shí)候就發(fā)現(xiàn)一個(gè)有保存的類型就把存的類型的字符串替換為空,代碼如下
方法三:(存鍵值和類型)
復(fù)制代碼 代碼如下:
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;
};
為了區(qū)別下不同數(shù)據(jù)的各種算法的效率差距,取幾種極端的例子來(lái)驗(yàn)證下,首先看看1-80全部數(shù)組項(xiàng)都不一樣循環(huán)1000次的情況,好吧,IE6弱爆了
IE9:
Chrome: 
Firefox:
IE6:
下面是80項(xiàng)全部重復(fù)的循環(huán)1000次的情況,綜合上面的數(shù)據(jù)一起發(fā)現(xiàn)除了IE6-8其它瀏覽器的雙重循環(huán)表現(xiàn)都不錯(cuò),而IE6-8雙重循環(huán)要慢10-20倍左右,悲催啊。如果你的網(wǎng)站只支持IE9以上的就可以放心用雙循環(huán)的方法了,否則還是使用健值的方法,根據(jù)數(shù)據(jù)的情況選擇使用方法一或方法三(圖中的方法四,才發(fā)現(xiàn)來(lái)不及改圖,原來(lái)的方法三是用了Array的indexOf,因?yàn)樗俣嚷也患嫒菥蜎](méi)放出來(lái)了)
IE9:
Chrome:
Firefox:
IE6:
您可能感興趣的文章:
- js數(shù)組去重的常用方法總結(jié)
- JS實(shí)現(xiàn)數(shù)組去重方法總結(jié)(六種方法)
- js數(shù)組去重的5種算法實(shí)現(xiàn)
- js取兩個(gè)數(shù)組的交集|差集|并集|補(bǔ)集|去重示例代碼
- 史上最全JavaScript數(shù)組去重的十種方法(推薦)
- JavaScript數(shù)組去重的兩種方法推薦
- js實(shí)現(xiàn)數(shù)組去重、判斷數(shù)組以及對(duì)象中的內(nèi)容是否相同
- js算法中的排序、數(shù)組去重詳細(xì)概述
- JavaScript數(shù)組去重的五種方法
- JS實(shí)現(xiàn)數(shù)組簡(jiǎn)單去重及數(shù)組根據(jù)對(duì)象中的元素去重操作示例
- JavaScript 高性能數(shù)組去重的方法
- 高性能js數(shù)組去重(12種方法,史上最全)
相關(guān)文章
javascript sudoku 數(shù)獨(dú)智力游戲生成代碼
javascript sudoku 數(shù)獨(dú)智力游戲生成代碼,喜歡的朋友可以參考下。2010-03-03
絕對(duì)經(jīng)典的滑輪新聞顯示(javascript+css)實(shí)現(xiàn)
這篇文章主要介紹了絕對(duì)經(jīng)典的滑輪新聞顯示(javascript+css)實(shí)現(xiàn),需要的朋友可以參考下2007-03-03
JS動(dòng)態(tài)添加option和刪除option(附實(shí)例代碼)
option的添加和刪除通過(guò)js實(shí)現(xiàn)及動(dòng)態(tài)創(chuàng)建select,本例提供實(shí)例的完整代碼,感興趣的朋友可以參考下哈,希望可以幫助到你2013-04-04
HTML5基于Tomcat 7.0實(shí)現(xiàn)WebSocket連接并實(shí)現(xiàn)簡(jiǎn)單的實(shí)時(shí)聊天
WebSocket 是一種自然的全雙工、雙向、單套接字連接。這篇文章給大家介紹了HTML5基于Tomcat 7.0實(shí)現(xiàn)WebSocket連接并實(shí)現(xiàn)簡(jiǎn)單的實(shí)時(shí)聊天,感興趣的朋友一起學(xué)習(xí)吧2016-10-10
JavaScript數(shù)據(jù)分析之交集,并集,對(duì)稱差集
這篇文章主要介紹了JavaScript數(shù)據(jù)分析之交集,并集,對(duì)稱差集,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-07-07

