gpt4 book ai didi

javascript - JS : Why Is This Slower? 它不应该测试其他 OR 条件但它确实如此?

转载 作者:可可西里 更新时间:2023-11-01 02:48:57 24 4
gpt4 key购买 nike

我刚刚测试了一些东西。我一直认为在 OR 条件下,一旦计算机/浏览器发现某些东西是真的,它就会返回它并且不会测试其他条件。我围绕这个假设构建了我的代码。

但是,我对它进行了计时,看起来长测试花费了 x4 倍,对此有什么解释吗?

注意:已在 Google Chrome 控制台中测试。

JSPerf:

http://jsperf.com/or-condition 返回真|| 1

http://jsperf.com/or-condition2 var 条件 = 真 || 1;返回条件;

http://jsperf.com/or-condition3 if(true || 1) return true 好像比较快

编辑:我刚刚发现 true 之后的条件数量并不重要。重要的是条件的长度。检查http://jsperf.com/or-condition5 .

我的理论是,浏览器将函数拆分为 2 个以上不同的内存区域,因为它的长度。当它调用该函数时,它需要从多个内存区域而不是 1 个内存区域获取数据。

a = function(){
return true ||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1||1;
}
b = function(){
return true;
}
//#############################################

var start = Date.now();
for(var i = 0 ; i < 1000000 ; i++){
a();
} var end = Date.now();
console.log(end-start); //3075


var start = Date.now();
for(var i = 0 ; i < 1000000 ; i++){
b();
} var end = Date.now();
console.log(end-start); //776

最佳答案

当条件变得更长更复杂时,JS 引擎需要更长的时间来分析代码行。

我相信this JSPerf test可以很好的解释。

关于javascript - JS : Why Is This Slower? 它不应该测试其他 OR 条件但它确实如此?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24564902/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com