HotSpot中包含的收集器如下图所示:
HotSpot的垃圾收集器
一般包括:
参数 | 描述 |
---|---|
UseSerialGC | 虚拟机在Client模式下的默认值,使用Serial+Serial Old收集器组合进行内存回收 |
UseParNewGC | 打开后,使用ParNew+Serial Old的收集器组合进行内存回收 |
UseConcMarkSweepGC | 打开后,使用ParNew + CMS + Serial Old的组合进行回收,其中Serial Old作为CMS收集器出现Concurrent Mode Failure失败后的后备收集器使用 |
UseParallelGC | 在Server模式下的默认值,打开后使用Parallel Scavenge+Serial Old(PS MarkSweep)收集器组合进行回收 |
UseParallelOldGC | 打开后,使用Parallel Scavenge + Parallel Old组合进行内存回收 |
SurvivorRatio | 新生代中Eden区域和Survivor区域的容量比值,默认是8,也就是Eden:Survivor = 8:1 |
PretenureSizeThreshold | 直接晋升到老年代的对象大小,设置这个参数之后,大于这个参数的对象将直接在老年代分配。 |
MaxTenuringThreshold | 晋升到老年代的对象年龄,这个对象在坚持过一次Minor GC之后,年龄就增加1,当超过这个参数后进入老年代。 |
UseAdaptiveSizePolicy | 动态调整Java堆中各个区域的大小以及进入老年代的年龄 |
HandlePromotionFailure | 是否允许分配担保失败,即老年代的剩余空间不足以应付新生代的整个Eden和Survivor区的所有对象都存活的极端情况 |
ParallelGCThreads | 设置并行GC时进行内存回收的线程数 |
GCTimeRatio | GC时间占总时间的比例,默认为99%,即允许1%的GC时间,仅在使用Parallel Scavenge收集器时有效 |
MaxGCPauseMillis | 设置GC最大停顿时间,尽在使用Parallel Scavenge收集器时生效 |
CMSInitiatingOccupancyFraction | 设置CMS在老年代空间被使用多少之后触发垃圾收集,默认为68%。仅在CMS收集器时生效 |
UseCMSCompactAtFullConllection | 设置CMS收集器在完成垃圾收集后是否要进行一次内存整理,仅在CMS收集器时生效 |
CMSFullGCsBeforeCompaction | 设置CMS收集器在进行若干次垃圾回收后再启动一次内存碎片整理,仅在CMS收集器时生效 |