JavaScript:相同的代码需要不同的时间来执行

JavaScript: Same code take different time to execute

本文关键字:时间 执行 代码 JavaScript      更新时间:2023-09-26

首先我运行这个(在铬中):

var start;
var end;
start = (new Date()).getTime();
for(var i=0;i<10e5;i++);
end = (new Date()).getTime();
console.log('delay:' + (end-start));

输出: delay:2028
然后我运行这个:

function foo() {
    var start;
    var end;
    start = (new Date()).getTime();
    for(var i=0;i<10e5;i++);
    end = (new Date()).getTime();
    console.log('delay:' + (end-start));
}
foo();

输出: delay:8

为什么在函数中包装时花费相同的代码更短的时间?

在节点中,它花费了相同的时间(6 和 6),但节点通过铬使用 V8 引擎,不是吗?

因为在函数中,所有变量都在闭包中。如果没有函数JavaScript解释器,请先尝试在全局范围内找到变量。

我认为

这种行为只出现在控制台中这一事实非常能说明问题。我怀疑这与 V8 引擎如何将脚本简化为本机代码有关。

要点#1:我怀疑范围不是减速的原因:

function foo() {
    start = (new Date()).getTime();
    for(i=0;i<10e5;i++);
    end = (new Date()).getTime();
    console.log('delay:' + (end-start));
}

此代码在全局范围内使用 startendi。如果搜索全局范围确实是瓶颈,那么此代码也应该运行缓慢,因为它在函数中没有局部变量。

要点#2:如果你把你的代码放在一个实际的网页中,无论哪种方式,它都会运行得非常快。 这向我表明,在控制台中运行代码是速度变慢的根源。

通常,在网页上,V8引擎将JavaScript组装成本机二进制代码,因此运行速度非常快。 但是,我怀疑从控制台运行的代码没有编译(或者在运行时可能逐行编译,这本身会产生时间成本)。 但是,当输入函数定义时,该函数在首次运行之前会完整编译。当程序流到达foo()调用时,函数foo已编译为本机代码。因此,函数运行速度很快,因为它已经过预编译,但控制台中的原始代码尚未预编译,因此运行缓慢。

这在很大程度上是猜测,但对这个问题的每个答案也是如此。 这是我唯一可以设计的解释,可以解释上述#1和#2点。