我们重点来说一下堆和栈:
栈内存:栈内存首先是一片内存区域,存储的都是局部变量,凡是定义在方法中的都是局部变量(方法外的是全局变量),for循环内部定义的也是局部变量,是先加载函数才能进行局部变量的定义,所以方法先进栈,然后再定义变量,变量有自己的作用域,一旦离开作用域,变量就会被释放。栈内存的更新速度很快,因为局部变量的生命周期都很短。
堆内存:存储的是数组和对象(其实数组就是对象),凡是new建立的都是在堆中(这句话还是不严谨,JVM中的逃逸分析就打破了这一点,详情请看链接:https://mp.csdn.net/postedit/81214178),堆中存放的都是实体(对象),实体用于封装数据,而且是封装多个(实体的多个属性),如果一个数据消失,这个实体也没有消失,还可以用,所以堆是不会随时释放的,但是栈不一样,栈里存放的都是单个变量,变量被释放了,那就没有了。堆里的实体虽然不会被释放,但是会被当成垃圾,Java有垃圾回收机制不定时的收取。
- 管理方式:栈内存存放的变量生命周期一旦结束就会被释放,而堆内存存放的实体会被GC不定时的回收。
- 空间大小:栈比堆小
- 碎片相关:栈产生的碎片远小于堆
- 分配方式:栈支持静态(编译时就分配好的)和动态分配,而堆仅支持动态分配
- 效率:栈的效率比堆高,因为内存块的排列本身就是堆栈结构 还有计算机底层内存空间本身也是堆栈结构,使得栈空间和底层结构更加符合;操作也简单 只涉及到 入栈和出栈两个指令。