javascript循环的性能问题
PHP中文网
PHP中文网 2017-04-11 12:29:51
[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的性能问题吧

PHP中文网
PHP中文网

认证高级PHP讲师

全部回复(3)
阿神
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 的执行顺序换了下,神奇了

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

阿神

Func没什么性能问题,var len不是很有必要,浏览器会做优化的。
Func2这样写很奇怪,为了减少loop次数,个人觉得主要开销processItem的执行,这个不会变,减少loop次数并不会有多大提升吧,引入了额外的idx自增操作,而且code很难看。

PHPz

达夫设备?没必要吧关注了吧,毕竟浏览器已经发展到现在了...

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号