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

JVM三色标记

三色标记

什么是三色标记法

三色标记法,也被称为Tri-color Marking Algorithm,是一种用于追踪对象存活状态的垃圾回收算法。它基于William D. Hana和Mark S. McCulleghan在1976年提出的两色标记法的基础上进行了改进。

与两色标记法只能将对象标记为“黑色”(已访问过)或“白色”(未访问过)不同,三色标记法引入了额外的“灰色”(正在被访问)状态。

黑色:代表该对象以及该对象下的属性全部被标记过了。(程序需要用到的对象,不应该被回收)

灰色:对象被标记了,但是该对象下的属性未被完全标记。(需要在该对象中寻找垃圾)

白色:对象未被标记(需要被清除的垃圾)

GC Roots

在Java语言中,“GC roots”, 或者说tracing GC的"根集合", 是一组必须活跃的引用

  1. 虚拟机栈(栈帧中的本地变量表)中引用的对象,譬如各个线程被调用的方法堆栈中使用到的参数、局部变量、临时变量等。

  2. 方法区中类静态属性引用的对象,譬如Java类的引用类型静态变量。

  3. 方法区中常量引用的对象,譬如字符串常量池(String Table)里的引用。

  4. 本地方法栈中 JNI(Native方法)引用的对象

在这里插入图片描述

工作原理

初始状态只有GC Roots是黑色的。被GC Roots直接引用的对象会变成灰色

扫描过程中,按照以下两点扫描整个引用链

  • 当前灰色节点没有子节点的话,将当前节点变为黑色。
  • 当前灰色节点有子节点的话,当前节点变为黑色,且子节点变为灰色。

扫描完成时,黑色对象就是存活的对象,白色对象就是已消亡可回收的对象

扫描完成之后,垃圾收集器只需要回收仍然是白色的对象所占用的内存即可。乍一看上面的过程好像没有什么问题,但是不要忘了我们的收集线程是和用户线程并发执行的

在这里插入图片描述

多标-浮动垃圾

在并发标记过程中,如果由于方法运行结束导致部分局部变量(gcroot)被销毁,这个gcroot引用的对象之前又被扫描过(被标记为非垃圾对象),那么本轮GC不会回收这部分内存。这部分本应该回收但是没有回收到的内存,被称之为“浮动垃圾”。浮动垃圾并不会影响垃圾回收的正确性,只是需要等到下一轮垃圾回收中才被清除。

另外,针对并发标记(还有并发清理)开始后产生的新对象,通常的做法是直接全部当成黑色,本轮不会进行清除。这部分对象期间可能也会变为垃圾,这也算是浮动垃圾的一部分。

漏标-读写屏障

漏标会导致被引用的对象被当成垃圾误删除,这是严重bug,必须解决,有两种解决方案: 增量更新(Incremental Update) 和原始快照(Snapshot At The Beginning,SATB) 。

增量更新就是当黑色对象插入新的指向白色对象的引用关系时, 就将这个新插入的引用记录下来, 等并发扫描结束之后, 再将这些记录过的引用关系中的黑色对象为根, 重新扫描一次。 这可以简化理解为, 黑色对象一旦新插入了指向白色对象的引用之后, 它就变回灰色对象了

原始快照就是当灰色对象要删除指向白色对象的引用关系时, 就将这个要删除的引用记录下来, 在并发扫描结束之后, 再将这些记录过的引用关系中的灰色对象为根, 重新扫描一次,这样就能扫描到白色的对象,将白色对象直接标记为黑色(目的就是让这种对象在本轮gc清理中能存活下来,待下一轮gc的时候重新扫描,这个对象也有可能是浮动垃圾)

以上无论是对引用关系记录的插入还是删除, 虚拟机的记录操作都是通过写屏障实现的。

相关文章:

JVM三色标记

三色标记 什么是三色标记法 三色标记法,也被称为Tri-color Marking Algorithm,是一种用于追踪对象存活状态的垃圾回收算法。它基于William D. Hana和Mark S. McCulleghan在1976年提出的两色标记法的基础上进行了改进。 与两色标记法只能将对象标记为“…...

UE5--物体卡片与材质入门

参考资料: 《Unreal Engine5 入门到精通》--左央 虚幻引擎5.2文档:https://docs.unrealengine.com/5.2/zh-CN/ 前言: 跟着左央老师的《Unreal Engine5 入门到精通》学习制作AI版胡闹厨房,把学习过程与学习到的东西归纳总结起来。 …...

ios 实现TEXT、DOC、PDF等文档读取与预览

文章目录 一、前言二、iCould相关配置三、功能实现3.1 UIDocumentPickerViewController 选取控制器3.2 读取文件3.3 文档预览3.3.1 下载并保存3.3.2 QLPreviewController预览文档四、总结一、前言 最近正在研发的项目有一个需求: 允许用户将iCloud中的文档上传,实现文件的流…...

智慧矿山:让AI算法提高未戴安全带识别率!

未穿戴安全带识别AI算法,作为智慧矿山的重要应用之一,不仅可以有效提高矿山工作人员的安全意识,还可以降低事故发生的概率。然而,识别准确率的提高一直是该算法面临的挑战之一。为了解决这个问题,研究人员不断努力探索…...

【Unity程序技巧】公共Update管理器

👨‍💻个人主页:元宇宙-秩沅 👨‍💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍💻 本文由 秩沅 原创 👨‍💻 收录于专栏:Uni…...

Node学习笔记之HTTP 模块

回顾:什么是客户端、什么是服务器? 在网络节点中,负责消费资源的电脑,叫做客户端;负责对外提供网络资源的电脑,叫做服务器。 http 模块是 Node.js 官方提供的、用来创建 web 服务器的模块。通过 http 模块…...

SD NAND对比TF卡优势(以CSNP4GCR01-AMW为例)

最近做的一个项目, 需要加大容量存储,这让我想到之前在做ARM的开发板使用的TF卡方案,但是TF卡需要携带卡槽的,但是有限的PCB板布局已经放不下卡槽的位置。 这个时候就需要那种能够不用卡槽,直接贴在板子上面&#xff0…...

在Espressif-IDE中使用Wokwi仿真ESP32

陈拓 2023/10/17-2023/10/19 1. 概述 在Espressif-IDE v2.9.0版本之后可直接在IDE中使用Wokwi模拟器。 1.1 什么是 Wokwi 模拟器? Wokwi 是一款在线电子模拟器,支持模拟各种开发板、元器件和传感器,例如乐鑫产品 ESP32。 Wokwi 提供基于浏…...

vue3里面vant组件的标签页使用?

一、绑一个v-model事件 二、让activeName的初始为0也就是默认是显示第一个标签页的下标 三、给标签页下面的东西进行一个判断 想让哪个优先显示就把哪个判断作为初始值存入...

【CSS】使用 CSS 实现一个宽高自适应的正方形

1. 利用 padding 或 vw <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><metaname"viewport"content"widthdevice-width, initial-scale1.0"><title>Document</title><st…...

Java Stream流详解

Stream API主要提供了两种类型的操作&#xff1a;中间操作 和 终止操作。 中间操作 中间操作是返回一个新的流&#xff0c;并在返回的流中包含所有之前的操作结果。它们总是延迟计算&#xff0c;这意味着它们只会在终止操作时执行&#xff0c;这样可以最大限度地优化资源使用。…...

localforage-本地存储的优化方案

前言 前端本地化存储算是一个老生常谈的话题了&#xff0c;我们对于 cookies、Web Storage&#xff08;sessionStorage、localStorage&#xff09;的使用已经非常熟悉&#xff0c;在面试与实际操作之中也会经常遇到相关的问题&#xff0c;但这些本地化存储的方式还存在一些缺陷…...

自学SLAM(4)《第二讲:三维物体刚体运动》作业

前言 小编研究生的研究方向是视觉SLAM&#xff0c;目前在自学&#xff0c;本篇文章为初学高翔老师课的第二次作业。 文章目录 前言1.熟悉 Eigen 矩阵运算2.几何运算练习3.旋转的表达4.罗德里格斯公式的证明5.四元数运算性质的验证6.熟悉 C11 1.熟悉 Eigen 矩阵运算 设线性⽅程 …...

C++:容量适配器(栈、队列、优先级队列)

目录 1.容器适配器 4.1 什么是适配器 4.2 STL标准库中的容器适配器 2.stack的使用 2.1 STL库中对stack的实现 3.queue的使用 3.1 STL库中对queue的实现 4.priority_queue使用 4.1模拟实现 priority_queue 5.deque 的简介 1.容器适配器 4.1 什么是适配器 适配器是一种…...

Java-IO流

文章目录 Java-IO流文件字节流文件字符流File类缓冲流转换流打印流数据流对象流 Java-IO流 JDK提供了一套用于IO操作的框架&#xff0c;为了方便我们开发者使用&#xff0c;就定义了一个像水流一样&#xff0c;根据流的传输方向和读取单位&#xff0c;分为字节流InputStream和…...

04、Python 爬取免费小说思路

目录 Python 爬取免费小说思路代码解析爬取东西基本的四行代码:user-agent安装模块从 bs4 导入 BeautifulSoup ,查询某个标签开头的数据筛选遍历获取小说的章节名称每章小说的链接获取请求网址的响应获取小说的内容筛选内容整理内容爬取下载到指定文件夹完整代码:Python 爬取…...

【前端vue面试】vue2

目录 computed和watchv-show和v-ifkey 的重要性v-for 和 v-if 不能一起使用&#xff01;click的event修饰符事件修饰符表单项修饰符 父子组件通讯生命周期父子组件生命周期顺序 $nextTickslot 插槽动态组件异步组件keep-alivemixin computed和watch computed 有缓存&#xff0…...

自然语言处理---Transformer机制详解之GPT模型介绍

1 GPT介绍 GPT是OpenAI公司提出的一种语言预训练模型.OpenAI在论文<< Improving Language Understanding by Generative Pre-Training >>中提出GPT模型.OpenAI后续又在论文<< Language Models are Unsupervised Multitask Learners >>中提出GPT2模型.…...

【论文阅读】点云地图动态障碍物去除基准 A Dynamic Points Removal Benchmark in Point Cloud Maps

【论文阅读】点云地图动态障碍物去除基准 A Dynamic Points Removal Benchmark in Point Cloud Maps 终于一次轮到了讲自己的paper了 hahaha&#xff0c;写个中文的解读放在博客方便大家讨论 Title Picture Reference and prenotes paper: https://arxiv.org/abs/2307.07260 …...

2023年传媒行业中期策略 AIGC从三个不同层次为内容产业赋能

基本面和新题材共振&#xff0c;推动传媒互联网行情上涨 AIGC 概念带动&#xff0c;传媒板块领涨 A 股 2023 年第一个交易日&#xff08;1 月 3 日&#xff09;至 6 月 2 日&#xff0c;申万传媒指数区间涨幅高达 48.38%&#xff0c;同时期沪深 300 跌幅为 0.25%&#xff0c;…...

用LabView和STC89C52打造智能温湿度报警系统(含上位机控制)

用LabView和STC89C52打造智能温湿度报警系统&#xff08;含上位机控制&#xff09; 在智能家居和工业监控领域&#xff0c;温湿度监测一直是核心需求之一。传统的手动记录方式早已无法满足现代场景对实时性和智能化的要求。本文将带你从零构建一套完整的智能温湿度报警系统&…...

动态数据源类型转换终极指南:轻松实现多数据源无缝切换

动态数据源类型转换终极指南&#xff1a;轻松实现多数据源无缝切换 【免费下载链接】dynamic-datasource dynamic datasource for springboot 多数据源 动态数据源 主从分离 读写分离 分布式事务 项目地址: https://gitcode.com/gh_mirrors/dy/dynamic-datasource dyna…...

深入解析ToTensor():从PIL到OpenCV的图像预处理最佳实践

1. ToTensor()的隐藏技能&#xff1a;不只是格式转换 很多人第一次看到ToTensor()这个函数名时&#xff0c;都会以为它只是简单地把图像数据转换成PyTorch的Tensor格式。但当我深入研究源码后才发现&#xff0c;这个函数背后藏着不少容易被忽略的重要细节。让我用一个实际项目中…...

告别结构体!手把手教你用Simulink.Signal配置汽车软件输入输出信号(含代码生成实战)

告别结构体&#xff01;手把手教你用Simulink.Signal配置汽车软件输入输出信号&#xff08;含代码生成实战&#xff09; 在汽车电子控制单元&#xff08;ECU&#xff09;开发中&#xff0c;Simulink模型到C代码的转换是核心环节。许多工程师第一次生成代码时会发现&#xff0c;…...

别再只会dir和cd了!Windows 11/10下PowerShell 7.x的10个高效命令与场景实战

Windows 11/10下PowerShell 7.x的10个高效命令与场景实战 你是否还在Windows系统中反复点击鼠标完成文件操作&#xff1f;是否还在为批量处理数据而苦恼&#xff1f;PowerShell 7.x作为微软新一代命令行工具&#xff0c;正在彻底改变Windows用户的工作方式。与传统的CMD相比&am…...

ECU测试全攻略:从硬件组成到量产验证

1. ECU测试入门&#xff1a;为什么你的车离不开这个小盒子 每次转动车钥匙时&#xff0c;那个藏在发动机舱角落的小黑盒就开始高速运转。这个不起眼的金属盒子就是ECU&#xff08;电子控制单元&#xff09;&#xff0c;它像汽车的大脑一样默默工作。我拆解过上百个不同型号的EC…...

Android手把手编写儿童手机远程监控App之JAVA基础

概述 上节嘟宝工程Git配置。这节开始讲解java基础,学习Java语法糖。Java 是由 Sun Microsystems 公司于1995年5月推出的 Java 面向对象程序设计语言。 Java 语言的语法与 C 语言和 C 语言很接近&#xff0c;但也丢弃了 C 中很少使用的、很难理解的、令人迷惑的那些特性&#x…...

基于TDC-GPX的多通道高精度时间测量系统设计与激光雷达应用

1. TDC-GPX芯片深度解析 第一次接触TDC-GPX芯片时&#xff0c;我被它81皮秒的时间分辨率震惊到了——这相当于光在真空中只传播了2.4厘米所需的时间。这款德国ACAM公司的旗舰产品确实配得上"时间数字转换器中的瑞士军刀"这个称号。让我带你从工程师视角拆解这颗神奇的…...

深入解析前端认证机制:从Cookie到OAuth2.0

1. 从Cookie到Token&#xff1a;前端认证的演进之路 记得我第一次接触网站登录功能时&#xff0c;被Cookie和Session绕得晕头转向。那时候为了弄明白为什么关闭浏览器后需要重新登录&#xff0c;整整花了两天时间调试代码。现在回头看&#xff0c;这些认证机制的演进其实反映了…...

SD-PPP完整实用指南:如何让Photoshop与AI绘图无缝协作

SD-PPP完整实用指南&#xff1a;如何让Photoshop与AI绘图无缝协作 【免费下载链接】sd-ppp A Photoshop AI plugin 项目地址: https://gitcode.com/gh_mirrors/sd/sd-ppp SD-PPP是一款革命性的Photoshop AI插件&#xff0c;它能将Adobe Photoshop与ComfyUI、Stable Diff…...