首页 > 其他分享 >对JVM G1的理解

对JVM G1的理解

时间:2022-11-15 00:56:21浏览次数:69  
标签:G1 标记 对象 region SATB 理解 GC JVM TAMS

NOTICE:本文仅记录本人对 JVM G1 的小小理解,没有详细记录每个点,若有误可指出

内存区域

G1 将堆分为各个 region,大小通过 G1HeapRegionSize 指定

region 分类
按 region 大小分
  1. 普通 region,存放大小小于普通 refion 容量的一半的对象
  2. humongous 区域,存放大对象
按功能来分
  1. 新老代
  2. 老年代(humongous 只能在老年代)

新对象进入

  1. 新对象根据大小进入普通 region /humongous
  2. 记忆集维护
    1. 本 region 维护一个记忆集,记忆集都是别的 region 对象指向本 region 的引用
    2. 写前屏障,处理 SATB,将修改前引用对象放入 SATB 队列
    3. 写后屏障,标记被修改的对象所在卡表为 dirty card

垃圾回收

回收依据

维护每个 region 中垃圾的价值(回收获得的空间大小以及所需时间的比值)大小,通过最大 GC 时间(-XX:MaxGCPauseMillis)优先处理价值大的 region

回收分类
  1. Young GC
  2. Mixed GC(老年代中的内存比例超过IHOP)
回收步骤
  1. 初始标记
    1. 标记 GC Root 直接关联的对象
    2. 生成原始快照
    3. 修改 TAMS 的值
    4. 需要 Stop the world
  2. 并发标记
    1. 从 GC Root 开始进行可达性分析
    2. 处理 SATB 记录的引用变动的对象
  3. 最终标记
    1. 处于并发阶段遗留的少量 SATB 记录
  4. 筛选回收
    1. 计算各个 region 回收价值
    2. 回收
      1. 将回收 region 中存活对象挪到空 region 中
      2. 清空原有 region
标记过程中问题处理
  1. 在并发标记中,有新对象生成
    1. 通过 TAMS 划分特定区域
    2. 新对象只能放在 TAMS 区域中,并且默认是黑色的
  2. 在并发标记进行可达性分析,引用变动的对象处理
    1. 使用 SATB 记录灰色到白色删除的引用
    2. 在最终标记以灰色的对象为根,重新扫描一次

概念解释

三色标记法
  1. 黑色意义为被访问过的对象,引用都扫描过,并且确认最后是存活的,GC Root 默认为黑色
  2. 灰色意义为被访问过的对象,有一个引用未被扫描过,未确定是否存活
  3. 白色意义为未被访问过的对象
对并发标记中对象引用变化处理
SATB
  1. 全称为 Snapshot At The Beginning
  2. Region 包含 5 个指针
    1. bottom
    2. previous TAMS
    3. next TAMS
    4. top
    5. end
  3. 作用流程
    1. 并发标记中,新创建的对象在 next TAMS -> top 之间,此区间默认为黑色,默认存活
    2. 灰色对象删除指向白色的引用,记录下来
    3. 以记录下来的灰色为根,重新扫描
Incremental Update
  1. 黑色插入新的指向白色的引用,记录下来
  2. 并发扫描结束后,以记录下来的黑色为根,重新扫描一遍

参考

https://blog.51cto.com/u_15072811/4679940

本文首发于cartoon的博客

标签:G1,标记,对象,region,SATB,理解,GC,JVM,TAMS
From: https://www.cnblogs.com/cartooon/p/16891095.html

相关文章

  • 如何理解Java中眼花缭乱的各种并发锁?
    在互联网公司面试中,很多小伙伴都被问到过关于锁的问题。今天,我给大家一次性把Java并发锁的全家桶彻底讲明白。包括互斥锁、读写锁、重入锁、公平锁、悲观锁、自旋锁、偏向......
  • Pthread 并发编程(二)——自底向上深入理解线程
    Pthread并发编程(二)——自底向上深入理解线程前言在本篇文章当中主要给大家介绍线程最基本的组成元素,以及在pthread当中给我们提供的一些线程的基本机制,因为很多语言的......
  • 形象理解:IO流
      IO流的体系结构 ......
  • 『NLP学习笔记』如何理解attention中的Q,K,V
    如何理解attention中的Q,K,V?文章目录​​一.如何理解attention中的Q,K,V?​​​​1.1.定义三个线性变换矩阵​​​​1.2.定义QKV​​​​1.3.自注意力计算​​​​1.3.1......
  • 级联删除和级联更新的理解?
    级联更新, 就是好比学生表中的的张三选了一门叫做高数的课程,在选课表中就有张三和高数共同组成的一条选课记录,如果级联更新,当学生表中的张三改名为张四,他的选课表中的张三......
  • 深度理解Redux原理并实现一个redux
    Redux的作用是什么Redux的作用在于实现状态传递、状态管理。在这里你可能会说了,如果是状态传递,那我props的传递不也是可以达到这样的效果吗?context上下文方案不也是可以达......
  • 安科瑞电能质量治理解决方案在民航机场的应用
    安科瑞陈盼1、概述  随着社会的发展,电力电子技术也不断发展,越来越多的非线性负载在电网中应用,导致的谐波问题也越来越严重,对人们的生活也产生了广泛的影响,对民航机场电力......
  • 说说你对Vue的keep-alive的理解
    什么是keep-alive在平常开发中,有部分组件没有必要多次初始化,这时,我们需要将组件进行持久化,使组件的状态维持不变,在下一次展示时,也不会进行重新初始化组件。也就是说,keep......
  • 理解字节序
    一、字节序计算机硬件有两种储存数据的方式:大端字节序(bigendian)和小端字节序(littleendian)比如数值0x2211使用两个字节储存:高位字节是0x22,低位字节是0x11。大端字节序:......
  • JVM垃圾回收器
     垃圾回收器:六中分代垃圾回收器,四种分区垃圾回收器---------------》ps+po  jdk1.8Serial:停止所有业务线程,垃圾回收线程才能执行垃圾回收ParallelScavenge垃圾回收......