JVM提出 Card Table 的概念:
Card Table:就是把老年代区域分为一个个的Card,每个Card 为512个字节,通过 CardTable(字节数组) 进行管理;
每一个数组项对应一个Card,数组里面的记录对应Card的状态,
如果当前Card里面有对象引用了年轻代的对象,将当前Card标记为Dirty(脏的)。
YoungGC时,如何使用CardTable:
YoungGC时,想用可达性分析算法扫描A是否被引用,会怎么操作呢:
1、通过 GC ROOT 扫描到B、D两个对象,查看B、D对象所对应Card是否Dirty,
2、发现 D 对象对应的Card不是Dirty,说明D对象所在的Card里面没有对象引用年轻代对象,所以放弃对D所在的Card的扫描。
3、发现 B 对象所在Card为Dirty,所以我们只用扫描B对象所在的Card区域;避免扫描整个堆区域,YongGC借助CardTable效率提高了不止一点点。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。