JVM之G1收集器

时间:2023-01-02 16:37:20

 

Garbage-First,面向服务端的垃圾收集器。

  • 并行与并发:充分利用多核环境减少停顿时间,
  • 分代收集:不需要配合其它收集器
  • 空间整合:整体上看属于标记整理算法,局部(region之间)数据复制算法,运作期间不会产生空间碎片
  • 停顿可预测,建立可以预测的停顿时间模型。

内存管理:

  • 将整个java堆划分为多个大小形同的区域region,新生代和老年代都是region的集合。可以有计划的避免在全区域内进行垃圾收集。
  • 回收方式:跟踪每一个region里面的垃圾堆积的价值大小(回收所得的空间大小以及所需耗费时间的经验值),维护一个优先列表,每次根据允许的回收时间,优先回收价值最大的region(GI名字由来),
  • region之间的引用,新生代和老年带之间的引用根据remebered set来避免全盘扫描,每一个region都维护一个remebered set,
  • 初始标记-》并发标记-》最终标记-》筛选回收,类CMS

JVM之G1收集器