垃圾回收算法:
引用计数法:
给对象分配一段额外的空间,用于维护一个计数器,对象增加了一个新的引用,则增加计数器的值。一个引用关系失效,则减少计数器的值。但是需要解决循环依赖的问题
可达性分析法:
通过根集合作为起始点,根据引用关系开始搜索。JVM中常见的根有线程栈帧,符号表,字符串表,对象监视器,元数据对象。
并发执行垃圾回收器: CMS,G1,ZGC,Shenandoah
ZGC 解决 G1的不足
G1 :YGC回收所有新生代分区,混合回收时回收所有的新生代分区和部分老年代分区;使用RSet管理对象引用关系
1. 停顿时间过长 : G1停顿 几十到几百毫秒
2.内存利用率不高 : 引用关系处理需要消耗额外的内存,一般占整个内存的1%到20%
3.支持内存有效,高于100GB,内存过大导致停顿时间增长
ZGC 设计目标
1. 支持4TB内存
2.停顿时间控制在10ms之内
3.对程序吞吐量影响小于15%
ZGC把一切能并发处理的工作都并发执行,G1的停顿时间主要来自 垃圾回收阶段的复制算法,在复制算法中,需要把对象转移到新的空间中,并且更新其他对象到这个对象的引用。ZGC就是把对象的转移也并发执行,从而满足停顿时间在10ms以下
GC 复制算法是利用From 空间进行分配的。当From 空间被完全占满时,GC 会将活动
对象全部复制到To 空间。当复制完成后,