第一个是声明过程
var:
遇到有var的作用域,在任何语句执行器都已经完成了声明和初始化,也就是变量提升并且拿到undefined的原因。
let:
解析器进入一个块级作用域,发现let关键字,变量只是先完成声明,并没有到初始化那一步。如果此时在作用域提前访问会报错 xx is not defined,这就是暂时性死区的由来。等到解析到有let那一行时,才会进入初始化阶段。如果let那一行是赋值操作,则初始化和赋值同时进行。
const和let一样。
第二个是内存分配
var:
会直接在栈内存里预分配内存空间,然后等到实
际语句执行时,再存储对应的变量,如果传的是引用类型,则在堆内存里开辟一个内存空间存储实际内容,栈内存会存储一个指向堆内存的指针
let:
不会在栈内存里预分配内存空间,而且在栈内存
分配变量的时候,会检查,如果有相同变量名存在就会报错
const:
不会分预配内存空间,栈内存分配变量时也会
做同样的检测。const存储的变量是不可修改的,所以对于基本类型来说无法修改定义的值,对于引用类型来说无法修改栈内存里分配的指针,但是可以修改指针指向的对象里面的属性
第三个是变量提升
let只是创建过程中提升,初始化过程并没有提升,所以会产生暂时性死区。
var的创建和初始化过程都提升了,所以赋值前访问会得到undefined
最新回复