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收集器:初始标记→并发标记→最终标记→筛选回收

相关推荐
YuTaoShao39 分钟前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展
VT.馒头1 小时前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
野犬寒鸦1 小时前
从零起步学习并发编程 || 第七章:ThreadLocal深层解析及常见问题解决方案
java·服务器·开发语言·jvm·后端·学习
猿小羽1 小时前
AIGC 应用工程师(3-5 年)面试题精讲:从基础到实战的系统备战清单
面试·大模型·aigc·agent·rag
网络安全-杰克2 小时前
Jmeter压力测试工具安装与使用
自动化测试·软件测试·测试工具·jmeter·职场和发展
June bug3 小时前
【PMP】敏捷Scrum实践
经验分享·职场和发展·学习方法·scrum
boooooooom3 小时前
Pinia必学4大核心API:$patch/$reset/$subscribe/$onAction,用法封神!
javascript·vue.js·面试
试着3 小时前
【huawei】机考整理
学习·华为·面试·机试
石去皿3 小时前
【嵌入式就业6】计算机组成原理与操作系统核心机制:夯实底层基础
c++·面试·嵌入式
闻哥4 小时前
Kafka高吞吐量核心揭秘:四大技术架构深度解析
java·jvm·面试·kafka·rabbitmq·springboot