JVM工作原理与实战(四十一):ShenandoahGC原理

专栏导航

JVM工作原理与实战

RabbitMQ入门指南

从零开始了解大数据


目录

专栏导航

前言

一、ShenandoahGC介绍

二、ShenandoahGC 1.0版本

三、ShenandoahGC 2.0版本

四、ShenandoahGC执行流程

总结


前言

JVM作为Java程序的运行环境,其负责解释和执行字节码,管理内存,确保安全,支持多线程和提供性能监控工具,以及确保程序的跨平台运行。本文主要介绍了ShenandoahGC、ShenandoahGC 1.0版本、ShenandoahGC 2.0版本、ShenandoahGC执行流程等内容。


一、ShenandoahGC介绍

ShenandoahGC与ZGC(Z垃圾收集器)在设计上存在着显著的差异。相较于ZGC的全新开发,ShenandoahGC在很大程度上是基于G1垃圾收集器的源代码进行改造的。因此,在算法选择、数据结构定义等多个方面,ShenandoahGC与G1展现出了很高的相似性。

  • ShenandoahGC在区域划分上沿用了G1的设计理念,确保了内存管理的有效性和高效性。

  • ShenandoahGC并未采用着色指针技术,而是通过优化对象头部的设计来实现并发转移过程。这种设计策略不仅简化了实现过程,同时也确保了垃圾收集器在高并发环境下的稳定运行。

  • ShenandoahGC目前存在两个主要版本:1.0版本和2.0版本。其中,1.0版本被集成在JDK8和JDK11中,而自后续版本的JDK起,均采用了更为先进和稳定的2.0版本。这种版本迭代不仅反映了技术的不断进步,也确保了ShenandoahGC能够持续适应和满足不断变化的应用需求。

二、ShenandoahGC 1.0版本

在ShenandoahGC的1.0版本中,为了支持其并发转移机制,每个对象的前8个字节被扩展,增加了一个前向指针(Forwarding Pointer)。这个前向指针的作用是指向转移之后的对象;如果转移尚未完成,它将指向对象本身。

在转移阶段进行时,转移前的对象和转移后的对象会同时存在于内存中。当应用程序线程尝试访问这些数据时,ShenandoahGC会利用读前屏障(Read Barrier)机制,通过前向指针定位到转移后的对象,并读取该对象的数据。

对于写入操作,ShenandoahGC采用了写前屏障(Write Barrier)。在写入数据前,写前屏障会检查对象头部的Mark Word中的GC状态。如果GC状态为0,表示当前没有垃圾回收过程正在进行,线程可以直接进行写入操作。如果GC状态不为0,则根据状态值确定当前垃圾回收的具体阶段,并可能要求用户线程执行与垃圾回收相关的任务。

然而,1.0版本的设计也存在一些显著的缺点:

  • 内存占用增加:由于每个对象都需要额外的8个字节来存储前向指针,这导致整体对象内存占用显著增加,通常会增加5%到10%的空间开销。
  • 读屏障性能开销:在读前屏障中加入了复杂的指令处理逻辑,这可能会增加处理器的负担,从而影响应用程序的整体性能。

三、ShenandoahGC 2.0版本

为了解决这些问题,ShenandoahGC的2.0版本对前向指针的位置进行了优化,仅在转移阶段将其临时放入Mark Word中,从而减少了内存占用和读屏障的性能开销。这种改进使得ShenandoahGC在保持高效垃圾收集的同时,也更好地适应了不同的应用场景。

四、ShenandoahGC执行流程

  • 初始标记(STW)阶段:在这一阶段,所有的用户线程都会被暂停。ShenandoahGC会标记所有由Gc Roots直接引用的对象为存活状态。由于此阶段涉及的对象数量相对较少,因此造成的停顿时间通常非常短暂,从而最大限度地减少了应用程序的暂停时间。
  • 并发标记阶段:此阶段是与用户线程并发执行的,即垃圾收集器与用户线程同时运行。在这个阶段,ShenandoahGC会遍历堆上的所有对象,通过跟踪对象的引用关系,标记出所有可达的存活对象。为了加速这一过程,用户线程也会协助进行对象的标记工作。
  • 标记结束(STW)阶段:当并发标记阶段完成后,会进入另一个短暂的STW事件。这一阶段主要用于进行一些整理性的工作,例如处理那些在并发标记阶段未被标记的对象(即被认定为垃圾的对象),并为下一个阶段(并发转移)做好准备。
  • 并发转移阶段:此阶段同样是与用户线程并发执行的。在这个阶段,ShenandoahGC会将标记为存活的对象从旧的内存区域转移到新的内存区域中。这样做的好处是可以减少内存碎片,并提高未来垃圾收集的效率。
  • 并发重映射阶段:最后一个阶段是并发重映射。在这个阶段,ShenandoahGC会遍历所有的引用,将那些原本指向旧对象的引用更新为指向新对象。这样做可以确保应用程序在继续执行时,能够正确地访问到已经被移动的对象。

通过上述五个阶段的协同工作,ShenandoahGC能够在保持低延迟的同时,有效地管理内存并进行垃圾回收。

并发转移阶段的并发问题

在并发转移阶段,ShenandoahGC面临一个关键的并发问题。当用户线程协助进行对象转移的同时,ShenandoahGC线程也可能发现同一个对象需要被复制。在这种情况下,为了确保数据的一致性和完整性,ShenandoahGC会尝试使用类似比较并交换(CAS, Compare-And-Swap)的机制来写入前向指针。CAS是一种原子操作,它允许线程在写入共享数据之前先检查该数据的当前值。只有当当前值与预期值相匹配时,写入操作才会执行。这确保了只有一个线程能够成功修改前向指针,从而避免了并发冲突。如果CAS操作失败,即当前值与预期值不匹配,那么执行CAS操作的线程会放弃当前的转移操作,并允许其他线程尝试执行。

通过这种机制,ShenandoahGC在并发转移阶段能够确保数据的一致性和完整性,同时保持高并发性能。它允许用户线程和垃圾收集线程同时工作,从而提高了整体的系统吞吐量。


总结

JVM是Java程序的运行环境,负责字节码解释、内存管理、安全保障、多线程支持、性能监控和跨平台运行。本文主要介绍了ShenandoahGC、ShenandoahGC 1.0版本、ShenandoahGC 2.0版本、ShenandoahGC执行流程等内容,希望对大家有所帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/418300.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ywtool check命令及ywtool clean命令

一.ywtool check命令 1.1 ywtool check -I 1.2 ywtool check all 1.3 ywtool check io 1.4 ywtool check elk 1.5 ywtool check php 1.6 ywtool check mysql 1.7 ywtool check nginx 1.8 ywtool check system 1.9 ywtool check docker_nbip [容器名称] 1.10 ywtool check 1.10…

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之FlowItem容器组件

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之FlowItem容器组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、FlowItem组件 子组件 可以包含子组件。 接口 FlowItem() 使用该接口来…

从0到1使用C++实现一个模拟器-1-【实现最简CPU】

文章目录 uint64_tstdstd::arrayCPU和CU类构造函数size_tstatic_caststd::ifstreamriscv64-unknown-elf-objcopy -O binary add-addi add-addi.binriscv64-unknown-elf-gcc -Wl,-Ttext0x0 -nostdlib -o add-addi add-addi.s-wlstd::hex std::setw() std::setfill()各自的用法he…

DOM 创建节点、添加节点和删除节点

创建元素节点 document.createElement(‘标签名’) 创建文本节点document.createTextNode ( 内容 ) 根据传入的标签名创建出一个空的元素对象创建出来的默认不显示,要成为别人的子元素才能显示,所以要结合appendChild使用 添加节点(后面&am…

【数据结构与算法】回溯法解题20240301

这里写目录标题 一、78. 子集1、nums [1,2,3]为例把求子集抽象为树型结构2、回溯三部曲 二、90. 子集 II1、本题搜索的过程抽象成树形结构如下: 三、39. 组合总和1、回溯三部曲2、剪枝优化 四、LCR 082. 组合总和 II1、思路2、树形结构如图所示:3、回溯…

Kaggle 竞赛入门

打比赛不用写算法源码,应用的时候不用自己写。学习的时候可以自己写。 Kaggle 竞赛入门 认识 Kaggle 平台Kaggle竞赛知识前提结构化数据前提图像数据文本数据 Kaggle竞赛套路一个赛题的完整流程 认识 Kaggle 平台 Kaggle 官网 主页,比赛(数据…

Git分布式版本控制系统——git学习准备工作

一、Git仓库介绍 开发者可以通过Git仓库来存储和管理文件代码,Git仓库分为两种: 本地仓库:开发人员自己电脑上的Git仓库 远程仓库:远程服务器上的Git仓库 仓库之间的运转如下图: commit:提交&#xff…

【HbuilderX】 uniapp实现 android申请权限 和 退出app返回桌面

目录 android申请权限: 监听用户是否开启权限或关闭权限: 退出app返回桌面: android申请权限: 首先在 manifest.json 内添加你所需要用到权限 添加权限插件 permission.js 一次就好1/权限插件 - Gitee.comhttps://gitee.co…

安装 docker 可视化工具 portainer

portainer 官方网站 https://www.portainer.io/ 一、portainer 介绍 Portainer是一款开源的容器管理平台,它提供了一个直观易用的Web界面,帮助用户管理Docker容器集群、镜像、卷等资源。Portainer 支持多种 Docker 环境,包括本地Docker、Sw…

k8s 存储卷详解与动静部署详解

目录 一、Volume 卷 1.1 卷类型 emptyDir : hostPath: persistentVolumeClaim (PVC): configMap 和 secret: 二、 emptyDir存储卷 2.1 特点 2.2 用途: 2.3 示例 三、 hostPath存储卷 3.1 特点 3.2 用途 …

面试经典 150 题 ---- 轮转数组

面试经典 150 题 ---- 轮转数组 轮转数组方法一:使用额外的数组方法二:数组翻转 轮转数组 方法一:使用额外的数组 我们可以使用额外的数组来将每个元素放至正确的位置。用 n 表示数组的长度,我们遍历原数组,将原数组…

Jenkins笔记(一)

个人学习笔记(整理不易,有帮助点个赞) 笔记目录:学习笔记目录_pytest和unittest、airtest_weixin_42717928的博客-CSDN博客 目录 一:简单了解 二:什么是DevOps 三:安装Jenkins 四&#xff1…

OSCP靶场--DVR4

OSCP靶场–DVR4 考点(1.windows:路径遍历获取私钥getshell 2.ssh shell中runas切换用户) 1.nmap扫描 ┌──(root㉿kali)-[~/Desktop] └─# nmap -sV -sC -p- 192.168.161.179 --min-rate 2000 Starting Nmap 7.92 ( https://nmap.org ) at 2024-02-29 07:14 EST…

nextjs13如何进行服务端渲染?

目录 一、创建一个新项目 二、动态获取后端数据进行服务端渲染出现的问题 三、nextjs13如何进行服务端渲染 nextjs13是nextjs的一个重大升级,一些原本在next12当中使用的API在nextjs13上使用十分不便。本文将着重介绍在nextjs13及以上版本当中进行服务端渲染的方…

一个基于增量同步数据库结构的工具 - Goose

嗨!大家好,我是波罗学。本文是 Golang 三方库推荐第四篇,系列查看:Golang 三方库。 上篇文章,我讨论了数据库 schema 同步的两种方式:增量和差异。今天,推荐一个基于 Go 实现的增量同步数据库 …

图像处理基础——频域、时域

傅里叶分析不仅仅是一个数学工具,更是一种可以彻底颠覆一个人以前世界观的思维模式。 一、什么是频域 时域 时域是信号在时间轴随时间变化的总体概括;频域是把时域波形的表达式做傅立叶等变化得到复频域的表达式,所画出的波形就是频谱图&a…

Android Termux安装MySQL并实现公网远程连接本地数据库

文章目录 前言1.安装MariaDB2.安装cpolar内网穿透工具3. 创建安全隧道映射mysql4. 公网远程连接5. 固定远程连接地址 前言 Android作为移动设备,尽管最初并非设计为服务器,但是随着技术的进步我们可以将Android配置为生产力工具,变成一个随身…

pix2pix-zero

pix2pix-zero:零样本图像到图像转换 论文介绍 Zero-shot Image-to-Image Translation 关注微信公众号: DeepGoAI 项目地址:https://github.com/pix2pixzero/pix2pix-zero 论文地址:https://arxiv.org/abs/2302.03027 本文介绍了一种名为…

live555学习 - 环境准备

环境:Ubuntu 16.04.7 ffmpeg-6.1 1 代码下载 最新版本: http://www.live555.com/liveMedia/public/ 历史版本下载 https://download.videolan.org/pub/contrib/live555/ 选择版本live.2023.01.19.tar.gz ps:没有选择新版本是新版本在…

深入理解计算机系统笔记

1.1 嵌套的数组 当我们创建数组的数组时,数组分配和引用的一般原则也是成立的。 例如,声明 int A[5][3]; 等价于下面的声明 typedef int row3_t[3]; row3_t A[5] 要访问多维数组的元素,编译器会以数组起始为基地址, (可能需…