微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐