栈内存
1 访问顺序
栈是一种先进后出的数据结构, 用于存放临时变量的一片内存.
它是一种特殊的列表,栈内的元素只能通过列表的一端访问,这一端称为栈顶,另一端称为栈底
2 存储数据
一般说栈内存主要存储基本数据类型, 包括 boolean, number, string, undefined, null, symbol 以及对象变量的指针(也就是堆内存地址)
![在这里插入图片描述](https://img-blog.csdnimg.cn/7c646574331648dca2be601a37c7fb73.png
堆内存
1 访问顺序
堆内存存储变量时没有规律可言, 他只会用一块足够大的空间来存储变量
2 存储数据
堆内存主要对引用类型做存储, 数据大小一般都是未知的,
那为什么会这么分配内存呢?
这是因为:引用值的大小会改变,所以不能把它放在栈中,否则会降低变量查寻的速度。反观他的引用地址的大小是固定的所以放在了栈中.
(这大概也是为什么null 作为一个 object 类型却存储在栈内存当中的原因)