JVM面试真题总结(八)

文章收录在网站:http://hardyfish.top/

文章收录在网站:http://hardyfish.top/

文章收录在网站:http://hardyfish.top/

文章收录在网站:http://hardyfish.top/

在这里插入图片描述

G1收集器如何划分堆内存?

G1收集器将整个堆划分成约 2048 个大小相同的独立 Region 区域

这些区域可以在逻辑上被划分为Eden区、Survivor区和Old区。

  • 与其他GC收集器不同的是,G1并不需要Eden区、Survivor区和Old区物理上连续存在
  • 而是可以分散在各个Region中。

每个Region都有一个用于垃圾回收的优先级,G1收集器会优先选择回收垃圾最多的Region

  • 这也是G1名字Garbage-First的由来。

G1收集器划分堆划分的好处是什么?

G1收集器重新划分了Java堆,主要是为了解决CMS收集器的一些问题,提高垃圾收集的效率

  • 以及更好地控制垃圾收集的停顿时间。

具体来说,有以下几点原因:

减少内存碎片

  • CMS收集器采用的是标记-清除算法,这样会导致大量的内存碎片。
  • 而G1通过将堆划分为多个大小相等的独立区域,可以更好地控制堆内存,避免出现大量内存碎片。

提高垃圾收集效率

  • G1收集器在后台维护了一个列表,记录了每个区域的垃圾对象的数量
  • 垃圾对象最多的区域会被优先回收,这样可以尽可能降低内存占用,提高效率。

控制垃圾收集的停顿时间

  • G1收集器在设计时就考虑到了暂停时间,它可以让用户指定最大的垃圾收集停顿时间
  • 然后系统会尽力保证按照用户的预期进行操作。

描述G1垃圾收集的工作过程

初始标记(initial mark)

  • 标记了从GC Root开始直接关联可达的对象。
  • STW(Stop the World)执行。

并发标记(concurrent marking)

  • 和用户线程并发执行,从GC Root开始对堆中对象进行可达性分析,递归扫描整个堆里的对象图,找出要回收的对象

最终标记(Remark)

  • STW,标记再并发标记过程中产生的垃圾。

筛选回收(Live Data Counting And Evacuation)

  • 制定回收计划,选择多个Region 构成回收集,把回收集中Region的存活对象复制到空的Region中
  • 再清理掉整个旧 Region的全部空间。需要STW。

比较CMS和G1垃圾收集器的异同点

区别一:使用的范围不一样

  • CMS收集器是老年代的收集器,可以配合新生代的Serial和ParNew收集器一起使用。

  • G1收集器收集范围是老年代和新生代。

    • 不需要结合其他收集器使用。

区别二:使用的算法不一样

  • CMS收集器是使用标记-清除算法进行的垃圾回收。

  • G1收集器使用的是标记-整理算法进行的垃圾回收。

区别三:CMS收集器和G1收集器的优劣性

  • CMS收集器以最小的停顿时间为目标的收集器,容易产生内存碎片。

  • G1收集器不会产生内存碎片。

区别四:垃圾回收的过程不一样

  • CMS收集器:初始标记→并发标记→重新标记→标记清楚

  • G1收集器:初始标记→并发标记→最终标记→筛选回收

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值