本文主要是介绍Shenandoah 和 ZGC 收集器总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
阅读前提:了解G1 等收集器。
Shenandoah
前言: Shenandoah 并不是Oracle 官方的收集器,所以 OracleJDK 甚至明确拒绝使用这个高效的垃圾收集器,商用的话可以使用OpenJDK。
该收集器与 G1 的不同有:
-
G1的回收阶段是可以多线程并行的,但是不能与用户线程并行,但是Shenandoah 回收阶段是可以与用户线程并发的,使用了转发指针等技术。
-
Shenandoah 默认不使用分代收集,然而G1 是分新生代和老年代这些的,所以没有专门的新生代和老年代的 Region 。
-
G1 消耗大量的内存去维护记忆集, Shenandoah 改用名为“连接矩阵”的全局数据结构来记录跨Region的引用关系降低了处理跨待指针是的记忆集维护消耗。
-
用户线程和收集器线程对转发指针的访问
-
使用CAS保证两者并发时能够正确访问
ZGC
ZGC 收集器是一款JDK 11 中新加入的具有实验性质的低延迟垃圾收集器,与Shenandoah 的目标相同,向往尽可能对吞吐量影响不大的前提下,实现在任意任意堆内存可以把垃圾收集停顿限制
这篇关于Shenandoah 和 ZGC 收集器总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!