自动提升会降低 JavaScript 的性能吗?

问题描述

最近,我正在研究 Javascript 中的 Scope。我想知道自动提升是在编译时完成还是在执行代码时(运行时)完成。如果在运行时确实如此,那么我还有一个问题,自动提升是否会降低 Javascript 程序的性能

something = a(); 
function a(){
 console.log("hoisting");
 return 10;
}
var something; 

我们应该使用手动吊装还是使用自动吊装更好?

解决方法

将我的评论作为答案:

人们对提升的含义有不同的理解。事实是,根据规范,每次调用一个函数时,都会创建一个新的执行上下文,其中包含一个新的环境。然后 the function body is processed 查找所有变量声明(varletconst(和函数声明))以及在新环境中创建这些名称的绑定。 var 声明用 undefined 初始化。然后身体被实际评估。

考虑到这一点,从引擎的角度来看,将 var 声明放在哪里并不重要,无论如何都必须处理整个主体。

话虽如此,如果实际实现没有缓存该信息,我会感到惊讶。毕竟,函数中的变量声明在函数调用之间不会改变。

,

据我所知,没有性能问题。初始化在编译时完成。所以不管你是在顶部还是底部初始化,JS引擎都会在编译时创建引用。

但是

如果在底部忘记初始化,默认会初始化为undefined。由于提升,在各自作用域的顶部声明 functionsvariables 被认为是一种做法。

JavaScript: What is Hoisting? (Recommended)

,

它不是在运行时完成的。 它在编译过程中。 所以它不会降低性能。 就在代码执行之前,编译器会扫描所有变量和函数声明,并将它们分配到内存中。