javascript循环的性能问题

查看:90
本文介绍了javascript循环的性能问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

var items = [];
for(var i = 0 ; i < 10000 ; i++){
    items.push(Math.random());
}
var processItem = function(x){
    return Math.sin(x)*10;
} ;
var Func = function(){
    var len = items.length;
    for(var i = 0; i < len ; i++){
        processItem(items[i]);
    }
};
var Func2 = function(){
    var idx = 0;
    var i = items.length >> 3;
    while(i--){
        processItem(items[idx++]);
        processItem(items[idx++]);
        processItem(items[idx++]);
        processItem(items[idx++]);
        processItem(items[idx++]);
        processItem(items[idx++]);
        processItem(items[idx++]);
        processItem(items[idx++]);
    }
    i = items.length - idx;
    while(i--){
        processItem(items[idx++])
    }
};

大家来说说上面函数Func和Func2的性能问题吧

解决方案

var items = [];

for (var i = 0; i < 10000; i++) {
    items.push(Math.random());
}

var processItem = function(x) {
    processItem.count++;
    return Math.sin(x) * 10;
};

var Func = function() {
    processItem.count = 0;
    console.time("test1");
    var len = items.length;
    for (var i = 0; i < len; i++) {
        processItem(items[i]);
    }
    console.timeEnd("test1");
    console.log(processItem.count);
};
var Func2 = function() {
    processItem.count = 0;
    console.time("test2");
    var idx = 0;
    var i = items.length >> 3;
    while (i--) {
        processItem(items[idx++]);
        processItem(items[idx++]);
        processItem(items[idx++]);
        processItem(items[idx++]);
        processItem(items[idx++]);
        processItem(items[idx++]);
        processItem(items[idx++]);
        processItem(items[idx++]);
    }
    i = items.length - idx;
    while (i--) {
        processItem(items[idx++]);
    }
    console.timeEnd("test2");
    console.log(processItem.count);
};

Func();
Func2();

上面第1种方法性能好,把 Func1 和 Func2 的执行顺序换了下,神奇了

唉,还是不要太在意这个事情了

这篇关于javascript循环的性能问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆