minjs1cn / weekly-learning

每周学习分享打卡
0 stars 0 forks source link

33 - 【经典面试】var、let、const的区别,以及实现原理是什么? #33

Open Guyidingsanyu opened 3 years ago

Guyidingsanyu commented 3 years ago

区别: 1.var和let用以声明变量,const用于声明只读的常量; 2.var声明的变量,不存在块级作用域,在全局范围内都有效,let和const声明的,只在它所在的代码块内有效; 3.let和const不存在像var那样的“变量提升”现象,所以var定义变量可以先使用,后声明,而let和const只可先声明,后使用; 4.let声明的变量存在暂时性死区,即只要块级作用域中存在let,那么它所声明的变量就绑定了这个区域,不再受外部的影响。 5.let不允许在相同作用域内,重复声明同一个变量; 6.const在声明时必须初始化赋值,一旦声明,其声明的值就不允许改变,更不允许重复声明;如const声明了一个复合类型的常量,其存储的是一个引用地址,不允许改变的是这个地址,而对象本身是可变的。

Guyidingsanyu commented 3 years ago

变量与内存之间的关系,主要由三个部分组成:变量名、内存地址、内存空间。 JS引擎在读取变量时,先找到变量绑定的内存地址,然后找到地址所指向的内存空间,最后读取其中的内容。当变量改变时,JS引擎不会用新值覆盖之前旧值的内存空间(虽然从写代码的角度来看,确实像是被覆盖掉了),而是重新分配一个新的内存空间来存储新值,并将新的内存地址与变量进行绑定,JS引擎会在合适的时机进行GC,回收旧的内存空间。 用const来举例:const定义变量(常量)后,变量名与内存地址之间建立了一种不可变的绑定关系,阻隔变量地址被改变,当const定义的变量进行重新赋值时,根据前面的论述,JS引擎会尝试重新分配新的内存空间,所以会被拒绝,便会抛出异常。

xieshiyi commented 3 years ago

https://es6.ruanyifeng.com/#docs/let#let-%E5%91%BD%E4%BB%A4