昨天看見 Lazy 兄弟重新更新了函數,現在他是這樣子寫的:

Array.prototype.uniq = function( " /> 秋霞午夜一级理论片久久,欧美三级在线完整版免费,精品国产原创在线观看视频

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

Javascript 更新 JavaScript 數組的 uniq 方法

上次寫的一篇《JavaScript 數組的 uniq 方法》,發現代碼的問題還是存在。比如如果數組內有 undefined 元素就無法過濾等。

昨天看見 Lazy 兄弟重新更新了函數,現在他是這樣子寫的:

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;
}按照他的說法:“這種解法在整個過程對原有數組的改變只有兩次,效率比其他兩種高了2個數量級左右!”,我實測了下此函數的效率,的確如此(測試連接點這里)。

我也重新編寫和更新了我的函數,現在看起來是這個樣子的:

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;
}由同一個頁面測試所得,效率還是 Lazy 兄弟的稍許快些。經過一點思考以后,我有了些一點點我的心得:

我的函數 for 嵌套可以用一個函數獨立(就如 Lazy 兄弟的 include 函數一樣)。在上述的情況下,調用函數會比循環判斷效率要高一些。 
數組的循環讀寫操作在數據量大的情況下應格外的注意效率問題 
Lazy 兄弟的結論:

對數組的改變開銷巨大,如果可能,盡量在不改變原有數組的情況下進行操作。
如最終需要改變數組自身,可將結果賦予原有數組來操作。另外,對于 length
的計算,似乎效率并未受其影響。Lazy 兄弟的 resultArr 數組按照他這樣的寫法就可以保存同樣的值,在這里贊一個(雖然我的函數經過一點小的修改也可以實現)。感興趣的朋友可以去 Lazy 的頁面去看看。

最后,推薦閱讀一下王元濤兄弟的 JavaScript 數組的 uniq 方法,萬分感謝。

JavaScript技術Javascript 更新 JavaScript 數組的 uniq 方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美人与动牲交XXXXBBBB免费 | 日韩精品a在线视频 | 开心片色99xxxx | 青青app| 亚洲精品欧美精品中文字幕 | 丰满的女友1在线观看 | 天天干夜夜曰 | 久久精品国产免费播高清无卡 | 男人天堂2018亚洲男人天堂 | 最新国产在线视频 | 国产精品爽爽久久久久久竹菊 | 伊人狠狠丁香婷婷综合尤物 | 冈本视频黄页正版 | 亚洲另类国产综合在线 | 7756短视频| 被高跟鞋调教丨vk | 欧美老少欢杂交另类 | 视频一区亚洲视频无码 | 亚洲精品第一页中文字幕 | 久久国语精品 | 精品无码人妻一区二区免费AV | 男子扒开美女尿口做羞羞的事 | 牛牛在线(正)精品视频 | 嘟嘟嘟影院免费观看视频 | 国产精品久久久亚洲偷窥女厕 | 天堂网久久 | 国产精品爽爽久久久久久蜜桃 | 91av影院| 国产精品久久久久久久AV下载 | 51国产偷自视频在线视频播放 | 年轻的的小婊孑2中文字幕 你是淫荡的我的女王 | 久久精品视频在线看99 | 琪琪热热色原日韩在线 | 伊人久久国产 | 少妇的肉体AA片免费观看 | 四虎影5151毛片在线看 | 牛牛精品专区在线 | 亚洲爆乳无码精品AAA片蜜桃 | 成人国内精品久久久久影 | 日日日夜夜在线视频 | 中文字幕视频免费在线观看 |