JVM G1源码分析和调优书 阅读笔记 一

本文介绍了JVM的G1垃圾回收器,重点关注其分区策略、内存分配、停顿预测模型、卡表与位图、对象头结构以及内存管理。G1将堆空间划分为大小可变的Region,并通过启发式方法确定新生代大小。在并发标记时使用BitMap跟踪对象分配。此外,还讨论了各种对象类型及其管理方式,如静态对象、堆对象等。G1通过RSet记录跨区域引用,优化垃圾回收效率。
摘要由CSDN通过智能技术生成

G1 垃圾回收器 分区 Heap Region,下限是1MB,上限是32MB,默认整个堆空间分为2048个分区region

1.通过G1HeapRegionSize可以指定大小,默认值为0

2.不指定region大小,由G1启发式推断HR大小 ---- 根据堆空间最大值和最小值,以及HR的个数进行推断

如果G1 是启发式推断新生代的大小,扩张时如果有空闲的分区列表,就直接加入到新生代分区列表。没有就分配新的分区,然后再加入到新生代分区列表。G1有一个线程专门抽样处理预测新生代列表的长度应该多大,并动态调整。

G1 自适应扩展内存空间,默认 计算 G1 GC 时间与应用时间占比不超过10%,就不需要扩展空间,GC时间超过这个阈值10%,可以动态扩展,还可以根据一个参数配置扩展的比例 (最少不能少于1M,最多是当前已分配内存的一倍)

2.2 G1 停顿预测模型

    根据这个模型统计计算出来的历史数据,来预测本次收集需要选择的堆分区数量。预测逻辑是基于衰减平均值和衰减标准差

2.3  卡表和位图

    GC 引入卡表是对内存的引用关系做标记,从而根据引用关系快速遍历活跃对象

    G1 在混合收集算法中用到了并发标记,在并发标记的时候,使用了bitMap来描述对象的分配情况

2.4 对象头 

      JVM 设计了对象的数据结构 :  对象头,实例数据和对齐填充 

     JVM 对象头 分为两部分 :

        标记信息 :位于MarkOop,包括锁状态,是否偏向锁,锁状态标志位(轻量级锁00,偏向锁01, GC

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值