JVM-三大垃圾回收算法
垃圾回收分类:
- Minor GC:新生代--------------------------->指Young区的垃圾回收过程
- Major GC:老年代--------------------------->指OId区的垃圾回收过程
- FuII GC:新生代+老年代---------------->Yound区和OId区一起执行的垃圾回收过程
- Major GC不能单独存在。Major GC 都会伴随着Minor GC
触发垃圾回收
- 当Eden区或者S区不够用了
- 老年代空间不够用了
- 方法区空间不够用了
- 调用System.gc()
- GC是由JVM自动完成的,根据JVM系统环境而定,所以出发的时机是不确定的。
垃圾回收算法
Mark-Sweep:标记清除算法
- 在堆内存中有很多对象,白色是空白区,灰色和碧蓝色是使用的空间,当我们触发System.gc()的时候,它整个处理过程的是根据整个堆当中去找.
- 通过可达性分析去判定-标记出来在这些对象中那些是存活的那些是需要给处理的。
- 当我们把标记死亡的对象给它清理掉。
- 优缺点:虽然标记清楚效率极高,但是标记清楚过后会形成内存碎片。(内存空间不连续)
Mark-Compact:标记-整理
- 通过可达性分析去判定-标记出来在这些对象中那些是存活的那些是需要给处理的。
- 把它们整理清楚
- 当我们把标记死亡的对象给它清理掉。
- 优缺点:它是通过大量不同的算法标记整理出来形成连续的空间。最终并不会出现空间碎片和浪费空间的问题,但是整理过程中带来的计算可不容小视。
Mark-Copy:复制-清除
复制算法把空间一份为二
- 通过可达性分析去判定-标记出来在这些对象中那些是存活的那些是需要给处理的。
- 把存活对象复制到另外一边,并清除无用的对象
- 优缺点:它可以解决空间碎片且计算耗时也非常低。但是它造成浪费空间(空间换时间)