什么是 Java 中的 logging write barrier?
什么是 Java 中的 Logging Write Barrier?
Logging Write Barrier 是 Java 垃圾回收器在维护堆引用关系时常用的一种机制。它是一种特殊的写屏障(Write Barrier),用于记录堆中某些引用的变化情况。该机制的主要目的是协助垃圾回收器在并发或增量标记阶段,正确跟踪对象引用的变化。
1. 什么是写屏障?
写屏障是垃圾收集器在应用程序线程(Mutator)执行写操作(对象字段赋值、数组元素更新等)时插入的一段额外代码,用来捕捉或记录引用的变化。写屏障的具体实现和目的因垃圾回收器的策略不同而有所不同。
常见的写屏障类型:
- Card Table Write Barrier:更新脏卡,标记哪些内存区域需要重新扫描。
- Logging Write Barrier:记录对象引用的变更(如 SATB 使用的缓冲区)。
- Remembered Set Write Barrier:维护跨代引用或跨分区引用的集合。
2. Logging Write Barrier 的原理
Logging Write Barrier 的核心功能是将引用的更新操作记录到一个缓冲区中,供垃圾回收器在并发或增量阶段处理。这一机制广泛用于垃圾回收器的并发标记阶段,比如 G1 和 Shenandoah GC。
工作流程:
对象引用更新:
- 当一个对象字段或数组元素的引用被更新时,触发 Logging Write Barrier。
记录变更:
- 写屏障将更新前的旧引用(旧值)记录到一个专用缓冲区中(例如 SATB 的缓冲区)。
回收阶段处理:
- 在垃圾回收的标记阶段,回收器会使用缓冲区中的信息来补偿并发期间遗漏的引用变更,确保标记过程的正确性。
3. Logging Write Barrier 的应用
3.1 G1 垃圾收集器中的应用
G1 使用 SATB(Snapshot-At-The-Beginning)算法来维护对象图的快照状态。Logging Write Barrier 是 SATB 的关键实现手段:
- 当 Mutator 删除某个对象的引用时,旧引用通过写屏障被记录到缓冲区中。
- 在并发标记阶段,回收器通过处理缓冲区中的旧引用,确保对象快照状态的一致性。
3.2 Shenandoah 垃圾收集器中的应用
Shenandoah 使用类似机制跟踪引用的变化,确保并发标记阶段的引用关系完整。
4. Logging Write Barrier 的优缺点
优点:
- 准确性高:能够捕捉 Mutator 对堆内引用的所有变更,避免遗漏对象引用。
- 支持并发标记:使得回收器在标记阶段能够与 Mutator 并发运行,提高性能。
- 实现简单:相比其他复杂机制,Logging Write Barrier 的实现相对直观。
缺点:
- 额外的开销:每次引用更新都会触发屏障逻辑,对程序性能有一定影响。
- 缓冲区管理成本:需要额外的内存来存储记录,并定期处理这些缓冲数据。
5. 总结
Logging Write Barrier 是一种记录堆内对象引用更新的机制,主要用于支持并发垃圾回收器的标记阶段。例如:
- G1 使用 Logging Write Barrier 配合 SATB,记录引用删除操作,维持标记阶段的快照一致性。
- Shenandoah 等其他回收器也采用类似机制以提高并发效率。
通过 Logging Write Barrier,可以在降低 STW 停顿时间的同时,保证垃圾回收器的标记过程准确可靠。
什么是 Java 中的 logging write barrier?的更多相关文章
- Java中的日志——Java.util.logging、log4j、commons-logging
Java中给项目程序添加log主要有三种方式,一使用JDK中的java.util.logging包,一种是log4j,一种是commons-logging.其中log4j和commons-loggin ...
- Java Se: Logging 框架说明
Java Logging 用惯了log4j等日志工具,竟然不知Java还自带了个log工具.今天有空了就来了解一下. 先来看一个简单的例子: public class SystemTest { pri ...
- java中多线程中Runnable接口和Thread类介绍
java中的线程时通过调用操作系统底层的线程来实现线程的功能的. 先看如下代码,并写出输出结果. // 请问输出结果是什么? public static void main(String[] args ...
- java中动态反射
java中动态反射能达到的效果和python的语法糖很像,能够截获方法的实现,在真实方法调用之前和之后进行修改,甚至能够用自己的实现进行特别的替代,也可以用其实现面向切片的部分功能.动态代理可以方便实 ...
- 你真的了解JAVA中与Webservice相关的规范和实现吗?
非常多人在项目中使用Webservice,仅仅是知道怎样公布Webservice,怎样调用Webservice,但真要论其来龙去脉,还真不一定清楚. 一切一切还要从我们伟大的sun公司规范说起. JA ...
- slf4j+log4j在Java中实现日志记录
小Alan今天来跟大家聊聊开发中既简单又常用但必不可少的一样东西,那是什么呢?那就是日志记录,日志输出,日志保存. 后面就统一用日志记录四个字来形容啦. 日志记录是项目的开发中必不可少的一个环节,特别 ...
- JAVA中使用log4j及slf4j进行日志输出的方法详解
JAVA中输出日志比较常用的是log4j,这里讲下log4j的配置和使用方法,以及slf4j的使用方法. 一.下载log4j的架包,并导入项目中,如下: 二.创建log4j.properties配置 ...
- Java 中Log4j的使用详情
Log4j 真的很简单,简单到令人发指的地步.不是要记录日志吗?那就给你一个Log ,然后你用Log 来写东西就行了,先来一个完整类示例: package test; import org.apach ...
- 第77节:Java中的事务和数据库连接池和DBUtiles
第77节:Java中的事务和数据库连接池和DBUtiles 前言 看哭你,字数:8803,承蒙关照,谢谢朋友点赞! 事务 Transaction事务,什么是事务,事务是包含一组操作,这组操作里面包含许 ...
- java中如何模拟真正的同时并发请求?
有时需要测试一下某个功能的并发性能,又不要想借助于其他工具,索性就自己的开发语言,来一个并发请求就最方便了. java中模拟并发请求,自然是很方便的,只要多开几个线程,发起请求就好了.但是,这种请求, ...
随机推荐
- Educational Codeforces Round 172 (Rated for Div. 2)(C-D)
题目链接:Dashboard - Educational Codeforces Round 172 (Rated for Div. 2) - Codeforces C. Competitive Fis ...
- THUWC2024 游记
省流:D1T3,Pretest 97,D2 和 4.so 决斗两小时(胜利). day 0 从成都早上坐火车,中午到了重庆. 坐轻轨到了酒店附近,虽然我不住酒店.lxs 带着吃了一碗面.重庆的面挺好吃 ...
- Luogu P1930 亚瑟王的宫殿 题解 [ 蓝 ] [ 分层图最短路 ] [ 枚举 ]
亚瑟王的宫殿:比较 tricky 的图论. 图论做法 思路 因为是无向图,所以考虑一个经典 trick,把所有点到集合点的距离之和化为集合点到其他所有点的位置之和,就可以从集合点做单源最短路了. 于是 ...
- Asp.Net Core3.0 微信转账到零钱
参考文档: 微信付款到零钱开发文档:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_2 用于向微信用户个人付款, ...
- 赶上AI的大潮:在VSCode中使用DeepSeek编程的极简方法
1 赶上AI的大潮:在VSCode中使用DeepSeek编程的极简方法 1.1 背景 DeepSeek在春节期间突然大行其道,欣喜国力大增的同时,对于普通IT工作者,如何才能享受这一波AI红利,让 ...
- Paxos算法:如何解决分布式系统中的共识问题?
背景 Paxos 算法是 Leslie Lamport(莱斯利·兰伯特)在 1990 年提出了一种分布式系统 共识 算法.这也是第一个被证明完备的共识算法(前提是不存在拜占庭将军问题,也就是没有恶意节 ...
- OpenCascade 开源的三维建模几何造型开发平台
官方文档 https://dev.opencascade.org/doc/overview/html/index.html Open CASCADE(简称OCC)平台是由法国Matra Datavis ...
- docker - [08] Portainer可视化面板安装
Docker图形化界面管理工具 一.运行容器 同时下载和使用镜像运行容器 docker run -d -p 8088:9000 \ --restart=always -v /var/run/docke ...
- AngleSharp :在 C# 中轻松解析和操作 HTML/XML 文档
AngleSharp 是一个 C# 库,主要用于解析和操作 HTML 和 XML 文档,类似于浏览器的 DOM 操作.允许你在 C# 中使用类似浏览器的方式处理网页数据,进行网页抓取.数据提取和处理等 ...
- 【攻防世界】catcat-new
catcat-new 题目来源 攻防世界 NO.GFSJ1168 题解 dirsearch爆破目录,得到http://61.147.171.105:55027/admin,没有有用信息 点开主页的图片 ...