在了解堆和栈的概念之前,首先明确下数据类型的分类。
- 基本数据类型:Number、String、Boolean、undefined、null
- 引用数据类型:Object
其中基本数据类型存放在栈中,而引用数据类型存放在堆和栈中,那么堆和栈到底有什么区别呢?先看下百度百科的解释。
堆栈空间分配
栈:由操作系统自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。
堆: 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收,分配方式倒是类似于链表。
堆栈缓存方式
栈使用的是一级缓存, 他们通常都是被调用时处于存储空间中,调用完毕立即释放。
堆则是存放在二级缓存中,生命周期由虚拟机的垃圾回收算法来决定。所以调用这些对象的速度要相对来得低一些。
堆栈数据结构区别
堆(数据结构):堆可以被看成是一棵树,如:堆排序。
栈(数据结构):一种先进后出的数据结构。
数据类型的访问模式
![](https://img.haomeiwen.com/i1884845/e03a879f6913ab66.png)
比如上方的代码,将a的值赋给b后,改变a的值,b并不会随之改变。
个人理解:由于基本数据类型存放在栈中,因此可以将a和b看成两个相互独立的变量,改变一个值对另一个变量并不会产生影响。而且在栈中存放的内存大小是固定的。
![](https://img.haomeiwen.com/i1884845/e9430a7457a60c7e.png)
引用数据类型则不然,把color1的值复制给color2后,改变其中任何一个变量的属性,另一个变量都会随之改变。由于引用数据类型复制的并不是属性本身的值,而是该属性存放的地址,地址存放在栈中,属性值存放在堆中,改变变量属性实际上就是改变栈中的属性值,但是地址是不变的,而此时两个变量所指的地址相同,因此改变一个属性,另一个就会随之改变。
![](https://img.haomeiwen.com/i1884845/f541f558b5487a93.png)
内存地址大小的固定的,因此可以将内存地址保存在栈内存中。 这样,当查询引用类型的变量时, 先从栈中读取内存地址, 然后再通过地址找到堆中的值。因为系统不知道需要多大内存存放数据,所以程序自己申请,这样就分配在堆里面。
网友评论