JVM-三大垃圾回收算法

垃圾回收分类:

  • Minor GC:新生代--------------------------->指Young区的垃圾回收过程
  • Major GC:老年代--------------------------->指OId区的垃圾回收过程
  • FuII GC:新生代+老年代---------------->Yound区和OId区一起执行的垃圾回收过程
  • Major GC不能单独存在。Major GC 都会伴随着Minor GC

触发垃圾回收

  1. 当Eden区或者S区不够用了
  2. 老年代空间不够用了
  3. 方法区空间不够用了
  4. 调用System.gc()
  • GC是由JVM自动完成的,根据JVM系统环境而定,所以出发的时机是不确定的。

垃圾回收算法

Mark-Sweep:标记清除算法
JVM-三大垃圾回收算法

  • 在堆内存中有很多对象,白色是空白区,灰色和碧蓝色是使用的空间,当我们触发System.gc()的时候,它整个处理过程的是根据整个堆当中去找.
  1. 通过可达性分析去判定-标记出来在这些对象中那些是存活的那些是需要给处理的。
  2. 当我们把标记死亡的对象给它清理掉。
  • 优缺点:虽然标记清楚效率极高,但是标记清楚过后会形成内存碎片。(内存空间不连续)

Mark-Compact:标记-整理
JVM-三大垃圾回收算法

  1. 通过可达性分析去判定-标记出来在这些对象中那些是存活的那些是需要给处理的。
  2. 把它们整理清楚
  3. 当我们把标记死亡的对象给它清理掉。
  • 优缺点:它是通过大量不同的算法标记整理出来形成连续的空间。最终并不会出现空间碎片和浪费空间的问题,但是整理过程中带来的计算可不容小视。

Mark-Copy:复制-清除
JVM-三大垃圾回收算法

复制算法把空间一份为二

  1. 通过可达性分析去判定-标记出来在这些对象中那些是存活的那些是需要给处理的。
  2. 把存活对象复制到另外一边,并清除无用的对象
  • 优缺点:它可以解决空间碎片且计算耗时也非常低。但是它造成浪费空间(空间换时间)

多敲一行代码未来老婆就漂亮一点