JVM GC有哪几种,有什么区别,分别有什么触发条件?

Minor GC:对象从新生代区域消失的过程,清理整个YoungGen,eden和S0/S1的清理都会由于MinorGC Allocation Failure(YoungGen区内存不足)而触发minorGC;

major GC:对象从老年代区域消失的过程,OldGen区内存不够而触发MajorGC;

Full GC:清理整个堆空间,包括新生代、老年代、永久代,触发的场景:

  • System.GC
  • 年代晋升失败,比如eden区存活的对象晋升到S区放不下,又尝试直接晋升到Old区还是放不下,那么Promotion Failed而触发FullGC;
  • CMS的Concurrent-Mode-Failure
    由于CMS回收过程中主要分为四步: 1.CMS initial mark 2.CMS Concurrent mark 3.CMS
    remark 4.CMS Concurrent sweep。在2中gc线程与用户线程同时执行,那么用户线程依旧可
    能同时产生垃圾, 如果这个垃圾较多无法放入预留的空间就会产生CMS-Mode-Failure, 切换
    为SerialOld单线程做mark-sweep-compact。
  • 新生代晋升的平均大小大于老年代的剩余空间 (为了避免新生代晋升到老年代失败)
    当使用G1,CMS 时,FullGC发生的时候 是 Serial+SerialOld。
    当使用ParalOld时,FullGC发生的时候是 ParallNew +ParallOld.
上一篇:2021_2_10


下一篇:SQL查询,去掉正负绝对值相等的记录