-
UseSerialGC
虚拟机运行在client模式下的默认值,打开此开关后,使用Serial+SerialOld的收集器组合进行内存回收。 -
UserParNewGC
使用ParNew+Serial Old的收集器组合进行内存回收 -
UserConMarkSweepGC:
使用ParNew+CMS+Serial Old的收集器组合进行内存回收。Serial Old收集器将作为CMC收集器出现Concurrent Mode Fail失败后的后被收集处理器使用 -
UserParallelGC:
虚拟机运行在client模式下的默认值,使用Parallel Scavenge+Serial Old
(ps MarkSweep)的收集器组合进行内存回收 -
UserParallelOldGC
使用Parallel+Scavenge+Parallel Old的收集器进行内存回收 -
SurvivorRatio
新生代中Eden区域与Survivior区域的容量比值,默认为8,代表Eden:Survicor = 8:1 -
PretenureSizeThreshold
直接晋升老年代对象的大小,设置这个参数后,大于这个参数的对象将直接在老年代分配。 -
MaxTenuringThreshold
晋升老年代的对象年龄,每个对象在坚持一次Minor GC之后,年龄就增加,当超过这个参数值时就进入老年代 -
UseAdaptiveSizePolicy
动态调整java堆中各个区域的大小以及进入老年代的年龄 -
HandlePromotionFailure
是否允许分配担保失败,即老年代的剩余空间不足以应付新生代的整个Eden和survivor区的所有对象都存活的极端情况 -
ParallelGCThreads
设置并行GC时进行内存回收的线程数 -
GCTimeRatio
GC时间占总时间的比率,默认值为99,即允许百分之一的GC时间,仅在使用Parallel Scavenge收集器时生效 -
MaxGCPauseMills
设置GC的最大停顿时间,仅在使用Parallel Scavenge收集器时生效 -
CMSInitiatingOccupancyFraction
设置CMS收集器在老年代空间被使用多少后触发垃圾收集。默认值为百分之68,仅在使用CMS收集器时生效 -
UseCMSCompactAtFullCollection
设置CMS收集器在完成垃圾收集后是否进行一次内存碎片整理,仅在使用CMS收集器时生效 -
CMSFullGCsBeforeCompaction
设置CMS收集器在进行若干次垃圾收集后在启动一次内存碎片整理。仅在使用CMS收集器时生效
注:新生代垃圾回收主要采用复制算法,即将新生代中存活的对象复制到另一块内存中。主要原因是新生代中存在大量的死对象。而老年代中主要使用标记-清除算法,标记-整理算法。