昨天看見(jiàn) Lazy 兄弟重新更新了函數(shù),現(xiàn)在他是這樣子寫(xiě)的:

Array.prototype.uniq = function( " /> 久久国产精品广西柳州门,香蕉视频啊啊啊,福利视频第一页

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

Javascript 更新 JavaScript 數(shù)組的 uniq 方法

上次寫(xiě)的一篇《JavaScript 數(shù)組的 uniq 方法》,發(fā)現(xiàn)代碼的問(wèn)題還是存在。比如如果數(shù)組內(nèi)有 undefined 元素就無(wú)法過(guò)濾等。

昨天看見(jiàn) Lazy 兄弟重新更新了函數(shù),現(xiàn)在他是這樣子寫(xiě)的:

Array.prototype.uniq = function() {
    var resultArr = [],
        returnArr = [],
        origLen = this.length,
        resultLen;

    function include(arr, value) {
        for (var i = 0, n = arr.length; i < n; ++i){
            if (arr[i] === value) {
                return true;
            }
        }

        return false;
    }

    resultArr.push(this[0]);
    for (var i = 1; i < origLen; ++i) {
        if (include(resultArr, this[i])) {
            returnArr.push(this[i]);
        } else {
            resultArr.push(this[i]);
        }
    }

    resultLen = resultArr.length;
    this.length = resultLen;
    for (var i = 0; i < resultLen; ++i){
        this[i] = resultArr[i];
    }

    return returnArr;
}按照他的說(shuō)法:“這種解法在整個(gè)過(guò)程對(duì)原有數(shù)組的改變只有兩次,效率比其他兩種高了2個(gè)數(shù)量級(jí)左右!”,我實(shí)測(cè)了下此函數(shù)的效率,的確如此(測(cè)試連接點(diǎn)這里)。

我也重新編寫(xiě)和更新了我的函數(shù),現(xiàn)在看起來(lái)是這個(gè)樣子的:

Array.prototype.uniq = function() {
    var tmp    = new Array;
    var length = this.length;

    for(var i = 0; i < length; i++) {
        var push = true;
        for(var j = i + 1; j < length; j++) {
            if(this[j] === this[i]) {
                push = false;
                break;
            }
        }

        if(push) {
            tmp.push(this[i])
        }
    }

    this.length = tmp.length;
    for (var i = 0; i < tmp.length; i++) {
        this[i] = tmp[i];
    }

    return tmp;
}由同一個(gè)頁(yè)面測(cè)試所得,效率還是 Lazy 兄弟的稍許快些。經(jīng)過(guò)一點(diǎn)思考以后,我有了些一點(diǎn)點(diǎn)我的心得:

我的函數(shù) for 嵌套可以用一個(gè)函數(shù)獨(dú)立(就如 Lazy 兄弟的 include 函數(shù)一樣)。在上述的情況下,調(diào)用函數(shù)會(huì)比循環(huán)判斷效率要高一些。 
數(shù)組的循環(huán)讀寫(xiě)操作在數(shù)據(jù)量大的情況下應(yīng)格外的注意效率問(wèn)題 
Lazy 兄弟的結(jié)論:

對(duì)數(shù)組的改變開(kāi)銷(xiāo)巨大,如果可能,盡量在不改變?cè)袛?shù)組的情況下進(jìn)行操作。
如最終需要改變數(shù)組自身,可將結(jié)果賦予原有數(shù)組來(lái)操作。另外,對(duì)于 length
的計(jì)算,似乎效率并未受其影響。Lazy 兄弟的 resultArr 數(shù)組按照他這樣的寫(xiě)法就可以保存同樣的值,在這里贊一個(gè)(雖然我的函數(shù)經(jīng)過(guò)一點(diǎn)小的修改也可以實(shí)現(xiàn))。感興趣的朋友可以去 Lazy 的頁(yè)面去看看。

最后,推薦閱讀一下王元濤兄弟的 JavaScript 數(shù)組的 uniq 方法,萬(wàn)分感謝。

JavaScript技術(shù)Javascript 更新 JavaScript 數(shù)組的 uniq 方法,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 玖玖国产 | 狠狠大日本亚洲香蕉亚洲 | 欧美精品日韩一区二区三区 | 国产h视频在线观看网站免费 | 伊人婷婷色| 色久在线| 加勒比综合网 | 欧美日韩一区二区亚洲 | 国产高清视频免费人人爱 | 一级做a爰片性色毛片武则天五则 | 九九视频免费精品视频免费 | a级精品九九九大片免费看 a加勒比一本东京 | 国产精品人伦久久 | 国内小情侣一二三区在线视频 | 国产自线一二三四2021 | 在线永久免费观看黄网站 | 国产福利免费视频 | 国产亚洲网站 | 欧美另类xxxx | 日韩久久中文字幕 | 精品亚洲国产国拍 | 天天久久狠狠伊人第一麻豆 | 91久久国产青草亚洲 | 午夜视频网站在线观看 | 2019天天操天天干天天透 | 激情亚洲 | 亚洲色欧美 | 国产乱码精品一区二区三上 | 欧美巨大另类极品videohd | 在线看精品 | www.日本在线观看 | 成年人香蕉视频 | 真实国产乱子伦精品一区二区三区 | 激情视频小说图片 | 免费一区二区三区免费视频 | 欧美日本高清一本二本三本 | 国产成人综合精品一区 | 久久久久久久久中文字幕 | 美女又美女又黄又免费网站 | 怡红院成人g影院 | 黄网免费在线观看 |