堆和栈的概念和区别

简介: 堆和栈的概念和区别

JVM内存划分

JVM内存的划分有五片:

  • 寄存器;
  • 本地方法区;
  • 方法区;
  • 栈内存;
  • 堆内存

栈内存:存储的都是局部变量,所以方法先进栈,然后再定义变量,变量有自己的作用域,一旦离开作用域,变量就会被释放。栈内存的更新速度很快,因为局部变量的生命周期都很短,先进后出,后进先出

堆内存:存储的是数组和对象(其实数组就是对象),凡是new建立的都是在堆中,堆中存放的都是实体(对象),实体用于封装数据,而且是封装多个(实体的多个属性),如果一个数据消失,这个实体也没有消失,还可以用,所以堆是不会随时释放的,但是栈不一样,栈里存放的都是单个变量,变量被释放了,那就没有了。堆里的实体虽然不会被释放,但是会被当成垃圾,Java有垃圾回收机制不定时的收取,堆是在运行时动态分配内存的,存储速度较慢,堆内存可以称为二级缓存,堆中的对象不会随时释放,一般需要开发人员自己回收它,先进先出,后进后出,

堆和栈的区别

堆和栈的区别

  • 栈内存存储的是局部变量,而堆内存存储的是实体对象。
  • 栈的更新速度要快于堆内存,因为局部变量的生命周期很短。 V栈 > V堆
  • 栈内存存放的变量生命周期一旦结束就会被释放,而堆内存存放的实体会被垃圾回收机制不定时的回收。
  • 共享性不同,栈内存是线程私有的,堆内存是所有线程共有的。
  • 栈使用一级缓存,通常是被调用时处于存储空间,调用完立即释放。
  • 堆存放在二级缓存中,生命周期由虚拟机的垃圾回收算法决定。
  • 堆是先进先出,后进后出,栈是先进后出,后进先出
  • 栈的空间远远小于堆的空间


目录
相关文章
|
2天前
|
前端开发 JavaScript 算法
JavaScript 中实现常见数据结构:栈、队列与树
JavaScript 中实现常见数据结构:栈、队列与树
|
4天前
|
存储 NoSQL C语言
数据结构——顺序栈与链式栈的实现-2
数据结构——顺序栈与链式栈的实现
数据结构——顺序栈与链式栈的实现-2
|
4天前
|
存储 C语言
数据结构——顺序栈与链式栈的实现-1
数据结构——顺序栈与链式栈的实现
数据结构——顺序栈与链式栈的实现-1
|
4天前
栈的基本应用
栈的基本应用
13 3
|
4天前
栈与队列理解
栈与队列理解
13 1
|
4天前
|
存储 算法
数据结构与算法 栈与队列
数据结构与算法 栈与队列
12 0
数据结构与算法 栈与队列
|
4天前
|
C++
数据结构(共享栈
数据结构(共享栈
9 0
|
4天前
|
C++
数据结构(顺序栈
数据结构(顺序栈
13 2
|
4天前
|
容器
【栈与队列】栈与队列的相互转换OJ题
栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。
11 0
|
4天前
|
存储
【栈】基于顺序表的栈功能实现
栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端 称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。
13 0