G1回收器: 区域分代化
既然我们已经有了前面几个强大的GC,为什么还要发布Garbage First(G1)GC?
原因就在于应用程序所对应的业务越来越庞大、复杂,用户越来越多
,没有GC就不能保证应用程序正常进行,而经常造成STW的GC又跟不上实际的需求,所以才会不断地尝试对GC进行优化。G1(Garbage-First)垃圾回收器是在Java7 update 4之后引入的一个新的垃圾回收器,是当今收集器技术发展的最前沿成果之一。
于此同时,为了适应现在不断扩大内存和不断增加的处理器数量
,进一步降低暂停时间(pause time),同时兼顾良好的吞吐量。
官方给G1设定的目标是在延迟可控的情况下获得尽可能高的吞吐量,所以才担当起"全功能收集器"的重任与期望。
为什么名字叫做Garbage First(G1)呢?
- 因为G1是一个并行回收器,它把堆内存分割为很多不相关的区域(Region)(物理上不连续的)。使用不同的Region来表示Eden、幸存者0区、幸存者1区、老年代等等。
- G1 GC有计划地避免在整个Java堆中进行全区域的垃圾收集。G1跟踪各个Region里面的垃圾维护积的价值大小(回收所获得的空间大小以及回收所需时间的经验值),在后台维护一个优先列表,
每次根据允许的收集时间,优先回收价值最大的Region。
- 由于这种方式的侧重点在与回收垃圾最大量的区间(Region),所以我们给G1一个名字: 垃圾优先(Garbege First)。
G1(Garbage-First)是一款面向服务端应用的垃圾收集器,主要针对配备多核CPU及大容量内存的机器
,以极高概率满足GC停顿时间的同时,还兼具高吞吐量的性能特征。
在JDK1.7版本正式启用,移除了Experimental,是JDK 9以后的默认垃圾回收器
,取代了CMS回收器以及Parallel + Parallel Old组合。被Oracle官方称为"全功能的垃圾收集器"
。
与此同时,CMS已经在JDK 9中被标记为废弃(deprecated)。在jdk8中还不是默认的垃圾回收器,需要使用-XX:+UseG1GC来启用。