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

相关推荐
哲伦贼稳妥1 小时前
程序人生-我的外服经历(4)
经验分享·程序人生·职场和发展
程序猿进阶1 小时前
如何在 Visual Studio Code 中反编译具有正确行号的 Java 类?
java·ide·vscode·算法·面试·职场和发展·架构
无名之逆1 小时前
云原生(Cloud Native)
开发语言·c++·算法·云原生·面试·职场和发展·大学期末
ZachOn1y4 小时前
Java 入门指南:JVM(Java虚拟机)—— 双亲委派模型(Parent Delegation Model)
java·jvm·后端·java-ee·团队开发·个人开发
andrew_12195 小时前
腾讯 IEG 游戏前沿技术 一面复盘
java·redis·sql·面试
andrew_12195 小时前
腾讯 IEG 游戏前沿技术 二面复盘
后端·sql·面试
寻求出路的程序媛6 小时前
JVM —— 类加载器的分类,双亲委派机制
java·jvm·面试
深鱼~6 小时前
【JVM】垃圾回收机制|死亡对象的判断算法|垃圾回收算法
jvm
Lill_bin6 小时前
JVM内部结构解析
jvm·后端·spring cloud·微服务·云原生·ribbon
视觉小鸟6 小时前
【JVM安装MinIO】
前端·jvm·chrome