当前位置: 首页 > article >正文

新生代对象垃圾回收如何避免全堆扫描

新生代垃圾回收如何避免全堆扫描:通过卡表 + 写屏障避免全堆扫描
在这里插入图片描述

卡表:
在做YGC的时候,需要判断年轻代里面的对象哪些是垃圾,这些对象可能被老年代的对象引用,
这时候判断年轻代的某个对象是不是垃圾的时候,就需要扫描整个老年代,看有没有老年代的
对象引用指向这个对象。这是一个很恐怖的事情。。。

所以有了Card table。将内存区域分成一个个的card,一个card中包含了多个对象,如果老年代
有一个card中的对象指回了年轻代,则将这个card标记为dirty。
具体哪个card是dirty的,使用一个字节数组来表示(就是一个很长数组,没一个位置要么是0,
要么是1,比如010000,表示1对应的位置的card就是dirty的)。
这样扫描的时候,只需要扫描dirty的card里面的对象。避免全堆扫描。

写屏障:
当老年代的对象指向了新生代的对象,写屏障就会将对应的卡页标记成脏。扫描的时候,只需要扫描脏页里面的对象。避免全堆扫描。
类似于于AOP操作,可以再引用变化之前,或者之后,进行一些额外的操作。

可能存在的问题:产生浮动垃圾。老年代里面的有些对象可能已经是垃圾对象了,那么扫描出来的新生代的对象还是垃圾对象。

==============
卡表:卡表通过将堆内存划分为一系列固定大小的内存块(称为“卡页”),并使用一个字节数组来记录每个卡页的状态(是否包含跨代指针)。1表示包含跨代指针,0表示没有。
当卡页内的对象发生变动,特别是出现了跨代引用的情况的时候,卡表会相应地更新,将涉及的卡页标记为“脏”(Dirty),对应的字节数组位置的值标记为1。这样,在垃圾收集过程中,只需要关注被标记为脏的卡页,而无需扫描整个内存区域,从而提高了垃圾收集的效率。


http://www.kler.cn/a/378110.html

相关文章:

  • 分布式光伏管理办法
  • 基于SpringBoot+Gpt个人健康管家管理系统【提供源码+答辩PPT+参考文档+项目部署】
  • 【OpenGL】vs中glsl高亮显示插件
  • RuoYi 样例框架运行步骤(测试项目自用,同学可自取)
  • Linux rabbitmq客户端 SimpleAmqpClient 源码编译
  • yolov8训练及测试(ubuntu18.04、tensorrt、ros)
  • 70B的模型需要多少张A10的卡可以部署成功,如果使用vLLM
  • 基于 Java 语言双代号网络图自动绘制系统
  • Vue 事件阻止 e.preventDefault();click.prevent
  • 使用GraphQL构建高效API
  • ArcGIS API for JavaScript 基础应用+实例展示+水波纹特效
  • SpringBoot整合minio服务
  • windows下用CMake构建使用protobuf的应用,编译使用VS2022
  • LeetCode 3226. 使两个整数相等的位更改次数
  • UML介绍-不同类间关系
  • 【Linux】从零开始使用多路转接IO --- poll
  • 利用 Direct3D 绘制几何体—8.光栅器状态
  • 刘艳兵-DBA021-升级到Oracle Database 12c时,关于使用Export/Import方法迁移数据的说法是正确的?
  • 第三次RHCSA作业
  • 【vue】11.Vue 3生命周期钩子在实践中的具体应用
  • 《JVM第1课》Java 跨平台原理
  • qt QScrollArea详解
  • Git 的特殊配置文件
  • FPGA实现串口升级及MultiBoot(十一)QuickBoot介绍
  • ‌MySQL中‌between and的基本用法‌、范围查询
  • 干货|前端项目一些响应式布局问题(固定宽度仍可以实现响应式)