• G1垃圾回收器


    一、G1特点

    1.同时注重吞吐量和低延时 ,默认暂停目标 200ms
    2.超大堆内存,将堆划分为多个大小相等的Region(区域)(值:1、2、4、8)
    每个区域都可以作为伊甸园幸村区老年代
    3.整体上是标记+整理算法,两个区域之间是复制算法

    二、执行过程

    在这里插入图片描述

    Young Collection

    会stw

    新创建的对象放到伊甸园,当放满,触发新生代的垃圾回收
    请添加图片描述
    新生代内存紧张,把伊甸园中存活的对象复制到幸存区
    请添加图片描述
    幸存区内存比较多了 对象存活年龄超过阈值,又会触发新生代垃圾回收
    一部分晋升到老年代
    不够年龄的复制到另一个幸存区
    请添加图片描述

    Young Collection+CM

    新生代垃圾回收+并发标记

    在YongGC时候会进行GCRoot的初始标记(不会STW)
    老年代占用堆空间比例达到阈值的时候(默认45%),进行并发标记(不会STW)

    请添加图片描述

    Mixed Collection

    最终标记 (STW)
    拷贝存活(STW)
    混合收集
    对伊甸园 幸存区 老年代 全面垃圾回收

    为了达到暂停时间短的目标,对于老年代的存活拷贝(G1是分区域的,其中很多区域都是老年代)不会全部回收,会回收一些释放空间最多的老年代

    在这里插入图片描述

    三、

    请添加图片描述
    CMS与G1一样:
    垃圾回收的速度跟不上新产生的垃圾,并发就失败了,就会退化为串行的收集,这时候会FullGC

    Young Collection跨代引用

    新生代垃圾回收 先可达性分析(先找gc roots,再沿着链找存活对象)找存活对象
    老年代引用新生代问题

    在这里插入图片描述
    根对象一部分来自老年代,老年代的存活对象很多,如果遍历整个老年代去找gcroots,显然效率低。

    采用crad技术(卡表)将老年代分为很多512k的区域

    如果一个card中有对象引用了新生代中的对象,就把card标记为脏card

    这样做gcroots遍历的时候就不用找整个老年代了,只需要关注脏card就可以了

    新生代中有个Remembered Set 记录老年代中的脏card

    引用变更的时候,通过写屏障更新脏card,这是异步操作,不会马上更新,先将更新的指令放到一个脏card的队列之中。后续让一个线程完成脏card的更新操作

  • 相关阅读:
    USB概念介绍
    [附源码]计算机毕业设计springboot学习帮扶网站设计与实现
    2023沈阳航空航天大学计算机考研信息汇总
    检测Windows安全缺陷工具wesng的学习与使用
    达索系统SOLIDWORKS Electrical机电一体化协同设计
    跳转打开新窗口
    ARM32开发——GPIO输入
    RabbitMQ原理(四):MQ的可靠性
    【Git 】常用指令
    Python大作业——爬虫+可视化+数据分析+数据库(可视化篇)
  • 原文地址:https://blog.csdn.net/weixin_45511599/article/details/125523492