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.
标签:触发,晋升,Failure,线程,GC,JVM,哪几种,CMS 来源: https://blog.csdn.net/HUBA_yosa/article/details/122042567