1、 分代
虚拟机中的共划分为三个代:
年轻代(Young Gen):eden和survivor-8:1:1
年老代(Old Gen):存储大对象,由survivor晋升
永久代(perm Gen):perm gen 含class metadata、class static variables和interned string,metaspace只含class metadata了,class static variables和interned string被移到java heap上去了(所以java heap使用肯定要大一点);默认情况下的metaspace 的极限size 取决于内存可以开多大,无需特意调节(可以通过MetaspaceSize&MaxMetaspaceSize调节),jdk1.8使用元空间(Metaspace)取代永久代,使用native memory,好处在于不在有OOM错误;同时由于Metaspace的分配具有和Java Heap相同的地址空间,因此Metaspace和Java Heap可以无缝的管理。
2、 GC类型
Partial GC:并不收集整个GC堆的模式
Young GC:只收集young gen的GC
Old GC:只收集old gen的GC。只有CMS的concurrent collection是这个模式
Mixed GC:收集整个young gen以及部分old gen的GC。只有G1有这个模式
Full GC/Major GC:收集整个堆,包括young gen、old gen、perm gen(如果存在的话)
3、 垃收集器组合
Serial GC算法:Serial Young GC + Serial Old GC (敲黑板!敲黑板!敲黑板!实际上它是全局范围的Full GC);
Parallel GC算法:Parallel Young GC + 非并行的PS MarkSweep GC / 并行的Parallel Old GC(敲黑板!敲黑板!敲黑板!这俩实际上也是全局范围的Full GC),选PS MarkSweep GC 还是 Parallel Old GC 由参数UseParallelOldGC来控制;
CMS算法:ParNew(Young)GC + CMS(Old)GC (piggyback on ParNew的结果/老生代存活下来的object只做记录,不做compaction)+ Full GC for CMS算法(应对核心的CMS GC某些时候的不赶趟,开销很大);
G1 GC:Young GC + mixed GC(新生代,再加上部分老生代)+ Full GC for G1 GC算法(应对G1 GC算法某些时候的不赶趟,开销很大);
4、 GC触发条件
young GC:当young gen中的eden区分配满的时候触发。注意young GC中有部分存活对象会晋升到old gen,所以young GC后old gen的占用量通常会有所升高
full GC:当准备要触发young GC时,如果发现前young GC的平均晋升大小比目前old gen剩余的空间大,则触发full GC;或者,如果有perm gen的话,要在perm gen分配空间但已经没有足够空间时,也要触发一次full GC;或者System.gc()、heap dump带GC,默认也是触发full GC处;
并发GC的触发条件就不太一样。以CMS GC为例,它主要是定时去检查old gen的使用量,当使用量超过了触发比例就会启动一次CMS GC,对old gen做并发收集;同时对于CMS,如果youngGC后无法找到大空间,则会提前触发一次Full GC。