本文主要是介绍JVM垃圾回收算法:标记-清除算法 、复制算法、 标记-整理算法、 分代收集算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 引言
- I 标记回收算法(Mark-Sweep)
- 算法
- 不足
- II 复制算法(Copying)
- III 标记整理算法(Mark-Compact)
- IV 分代收集(以上三种算法的集合体)
- 内存划分
- 新生代算法:Minor GC
- 老年代算法
- V 查看JVM堆分配
引言
垃圾回收(Garbage Collection,GC)
Java支持内存动态分配、垃圾自动回收。JVM垃圾回收算法整体上来看是分代收集算法,而S0、S1这两部分可以看做是标记-整理算法
I 标记回收算法(Mark-Sweep)
算法
分为 “标记” 和 “清除” 两个阶段
- 标记出所有需要回收的对象
- 统一回收所有被标记的对象
不足
- 效率问题。标记和清除两个过程的效率都不高
- 空间问题。标记清除之后,会产生大量不连续的内存碎片,内存碎片太多可能会导致以后需要分配较大对象时,无法找到足够的连续内存,而不得不提前触发另一次垃圾回收动作,执行垃圾回收也是一个耗费资源的动作,执行频率过高,会影响到程序的整体执行效率。 <
这篇关于JVM垃圾回收算法:标记-清除算法 、复制算法、 标记-整理算法、 分代收集算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!