jvm打破砂锅问到底- 为什么要标记或记录跨代引用

  1. 为什么要标记或记录跨代引用.
    ygc时, 直接把老年代引用的新生代对象(可能是对象区域)记录下来当做根, 这其实就是依据第二假说和第三假说, 强者恒强, 跨代引用少(存在互相引用关系的两个对象,是应该倾
    向于同时生存或者同时消亡的).

拿ygc老年代跨代引用对象当做根, 首先就免去了直接直接扫描老年代, 因为要遍历标记哪个新生代的对象存活, 必须从根开始找, 那假如新对象是通过老对象关联着根的, 这种情况是根可达. 这意味着要访问完所有老年代对象以及他的引用关系, 才能枚举刚才的根可达情况. 这显然很耗时, 这就是在fullgc遍历. 因此记录跨代引用就是为了避免这种情况. 造成的好处就是不用罗列根可达对象们的时候, 只用在新生代区域进行就行了, 不用管老年代对象, 免去其判断. 将这判断交给跨代引用的维护. (空间换时间), 这样ygc停顿时间是较短的

(是以下两条的讨论, 第一:弱分代假说: 弱者居多, 弱者就是指朝生夕死,

第二: 强分代假说: 强者恒强, 一个对象如果能持久一段gc次数而不消亡, 他突然消亡的可能性就很小, 或者说越难以消亡)

相关推荐
__土块__13 小时前
大厂后端一面模拟:从线程安全到分布式缓存的连环追问
jvm·redis·mysql·spring·java面试·concurrenthashmap·大厂后端
fly spider1 天前
一文概括 JVM 核心内容
jvm
brahmsjiang1 天前
Java类加载机制解析:从JVM启动到双亲委派,再到Android的特殊实现
android·java·jvm
cch89181 天前
C++、Python与汇编语言终极对比
java·开发语言·jvm
zshs0001 天前
从 HashMap 到基因法:同一套位运算思想,如何从 JVM 走到分布式数据库
jvm·数据库·分布式
彧翎Pro1 天前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm
minji...1 天前
Linux 线程同步与互斥(二) 线程同步,条件变量,pthread_cond_init/wait/signal/broadcast
linux·运维·开发语言·jvm·数据结构·c++
woai33642 天前
JVM学习-基础篇-常见引用
jvm·学习
それども2 天前
理解JVM参数 Xss 线程的栈大小
jvm
玛卡巴卡ldf2 天前
【Springboot6】内存泄漏OOM、VisualVM、Arthas、Prometheus Grafana监控、垃圾回收
java·jvm·springboot