JVM垃圾回收器参数总结

  1. UseSerialGC
    虚拟机运行在client模式下的默认值,打开此开关后,使用Serial+SerialOld的收集器组合进行内存回收。

  2. UserParNewGC
    使用ParNew+Serial Old的收集器组合进行内存回收

  3. UserConMarkSweepGC:
    使用ParNew+CMS+Serial Old的收集器组合进行内存回收。Serial Old收集器将作为CMC收集器出现Concurrent Mode Fail失败后的后被收集处理器使用

  4. UserParallelGC:
    虚拟机运行在client模式下的默认值,使用Parallel Scavenge+Serial Old
    (ps MarkSweep)的收集器组合进行内存回收

  5. UserParallelOldGC
    使用Parallel+Scavenge+Parallel Old的收集器进行内存回收

  6. SurvivorRatio
    新生代中Eden区域与Survivior区域的容量比值,默认为8,代表Eden:Survicor = 8:1

  7. PretenureSizeThreshold
    直接晋升老年代对象的大小,设置这个参数后,大于这个参数的对象将直接在老年代分配。

  8. MaxTenuringThreshold
    晋升老年代的对象年龄,每个对象在坚持一次Minor GC之后,年龄就增加,当超过这个参数值时就进入老年代

  9. UseAdaptiveSizePolicy
    动态调整java堆中各个区域的大小以及进入老年代的年龄

  10. HandlePromotionFailure
    是否允许分配担保失败,即老年代的剩余空间不足以应付新生代的整个Eden和survivor区的所有对象都存活的极端情况

  11. ParallelGCThreads
    设置并行GC时进行内存回收的线程数

  12. GCTimeRatio
    GC时间占总时间的比率,默认值为99,即允许百分之一的GC时间,仅在使用Parallel Scavenge收集器时生效

  13. MaxGCPauseMills
    设置GC的最大停顿时间,仅在使用Parallel Scavenge收集器时生效

  14. CMSInitiatingOccupancyFraction
    设置CMS收集器在老年代空间被使用多少后触发垃圾收集。默认值为百分之68,仅在使用CMS收集器时生效

  15. UseCMSCompactAtFullCollection
    设置CMS收集器在完成垃圾收集后是否进行一次内存碎片整理,仅在使用CMS收集器时生效

  16. CMSFullGCsBeforeCompaction
    设置CMS收集器在进行若干次垃圾收集后在启动一次内存碎片整理。仅在使用CMS收集器时生效

注:新生代垃圾回收主要采用复制算法,即将新生代中存活的对象复制到另一块内存中。主要原因是新生代中存在大量的死对象。而老年代中主要使用标记-清除算法,标记-整理算法。

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值