【JVM】垃圾收集器详解

你将学到

1. Serial 收集器

2. ParNew 收集器

3. Parallel Scavenge 收集器

4. Serial Old 收集器

5. Parallel Old 收集器

6. CMS 收集器

7. G1 收集器


在 Java 中,垃圾回收(GC)是自动管理内存的一个重要机制。HotSpot JVM 提供了多种垃圾收集器,供开发者根据不同的应用场景进行选择。每种垃圾收集器都有其独特的实现原理、优缺点以及适用场景。在这篇博客中,我们将详细介绍 HotSpot JVM 中的 7 种垃圾收集器,帮助开发者更好地理解它们,并在不同的项目中做出最优的选择。 

 HotSpot 虚拟机中的7个垃圾收集器,图中有连线的说明是可以一起搭配使用的,下面针对每一个垃圾收集器,作单独的讲解。


1. Serial 收集器

Serial收集器是在进行垃圾收集时,必须暂停其他所有工作线程(Stop The World)。Stop The World并不是啥好事,因为它会导致用户线程停止工作,所以有些真实应用来说是无法接受的。

总结:

  • Serial 翻译为串行,也就是说它以串行的方式执行Serial 是新生代的垃圾收集器
  • 算法:复制算法
  • HotSpot 虚拟机运行在客户端模式下的默认新生代收集器

2. ParNew 收集器

ParNew垃圾收集器Parallel Garbage Collector 的一个变种,它专门用于 年轻代(Young Generation) 的垃圾回收,ParNew 的设计目的是提高 年轻代垃圾回收的吞吐量,通常通过 并行处理 来缩短回收时间,减少停顿时间。

总结:

  • 垃圾收集时是多线程并行的
  • ParNew是新生代的垃圾收集器
  • 使用的是复制算法
  • 在 CMS 收集器中,ParNew 用于年轻代垃圾回收,而老年代则由 CMS 来进行回收。ParNew 和 CMS 共同合作,减少了老年代的 Full GC 触发次数,并优化了停顿时间
  • 使用 -XX:ParallelGCThreads 参数来设置GC线程数

3. Parallel Scavenge 收集器

Parallel Scavenge 收集器,是 HotSpot JVM 中的一种 年轻代(Young Generation) 垃圾收集器。它专注于提高 吞吐量,通过并行化的方式来减少垃圾回收过程中的时间开销。Parallel Scavenge 是基于 复制算法(Copying Algorithm)实现的,并且通过多线程的方式来加速垃圾回收过程。这里的吞吐量指 CPU 用于运行用户代码的时间占总时间的比值。

吞吐量 = 运行用户代码的时间/(运行用户代码的时间+运行垃圾收集的时间)

Parallel Scavenge收集器提供了两个参数用于精确控制吞吐量,分别是控制最大垃圾收集停顿时间 的-XX:MaxGCPauseMilis参数 以及直接设置吞吐量大小的-XX:GCTimeRatio参数。

总结

  • 吞吐量优先收集器
  • 新生代垃圾收集器
  • 算法:复制算法
  • 两个精确控制吞吐量的参数
    • 控制最大垃圾收集停顿时间:-XX:MaxGCPauseMilis。
    • 直接设置吞吐量大小:XX:GCTimeRatio。
  • GC 自适应的调节策略开关:开启开关,就不需要手动指定新生代的大小(-Xmm)、Eden 和 Survivor 区的比例、晋升老年代对象年龄等细节参数了。虚拟机会根据当前系统的运行情况收集性能监控信息,动态调整这些参数以提供最合适的停顿时间或者最大的吞吐量。(XX:+UseAdaptiveSizePolicy)

4. Serial Old 收集器

erial Old 收集器 是 HotSpot JVM 中的一种 老年代(Old Generation) 垃圾收集器。它是 Serial Garbage Collector 的一个扩展版本,用于全堆垃圾回收时处理老年代的内存。Serial Old 的设计理念和 Serial GC 一致,主要特点是使用 单线程 执行垃圾回收任务,适用于资源受限或者对垃圾回收停顿时间不敏感的场景。

总结

  • 老年代收集器
  • 算法:标记-整理算法
  • gc时暂停所有用户线程
  • 主要作为客户端模式下的HotSpot虚拟机使用,另外也作为CMS收集器并发收集发生Concurrent Mode Failure时的后备预案使用

5. Parallel Old 收集器

Parallel Old是Paralle Scavenge收集器的老年代版本,多线程并行收集。目前只能与新生代的Parallel Scavenge收集器搭配使用,可以说Parallel Old就是为Parallel Scavenge而生的。在这之前Parallel Scavenge收集器只能与老年代的Serial Old进行搭配,但是一个多线程,一个单线程,导致吞吐量并没有充分的提升,直到Parallel Old收集器出现。

总结:

  • Parallel Old为Parallel Scavenge而生,只能搭配Parallel Scavenge。
  • Parallel Old采用多线程
  • 算法:标记-整理
  • 在注重吞吐量以及处理器资源较为稀缺的场合,都可以优先考虑Parallel Scavenge加Parallel Old收集器这个组合
  • JDK 6时才开始提供

6. CMS 收集器

CMS(Concurrent Mark-Sweep) 收集器是 HotSpot JVM 提供的一种 低延迟 垃圾收集器,旨在减少垃圾回收过程中的停顿时间。它的主要目标是 最小化停顿时间,使得应用程序能够在垃圾回收的过程中尽可能保持运行状态,特别适用于对响应时间敏感的应用。

原理

CMS 收集器主要采用了 标记-清除(Mark-Sweep)算法,结合了并发执行来优化标记和清除阶段,减少了停顿时间。它的工作过程分为多个阶段:

  1. 初始标记(Initial Mark)

    • 初始标记阶段是 Stop-the-World 的,这意味着在这个阶段应用程序会暂停。该阶段会标记 GC Root 可达的对象。
    • 这个阶段会很快完成,因为只标记根对象的引用,不需要遍历整个堆。
  2. 并发标记(Concurrent Mark)

    • 在并发标记阶段,CMS 会并发地扫描整个堆,标记出所有存活的对象。
    • 这个阶段是 并发执行的,也就是说,在标记阶段,应用程序的线程可以继续运行,尽量减少停顿时间。
    • 但并发标记阶段的执行时间较长,且可能需要使用多个 CPU 核心来加速标记过程。
  3. 重新标记(Remark)

    • 在并发标记完成后,还需要进行 重新标记 阶段。这个阶段用于标记在并发标记过程中被修改的对象(即那些在并发标记过程中被修改了引用关系的对象)。此阶段也是 Stop-the-World 的,因此应用程序会暂停。
    • 重新标记是一个很短的阶段,主要用于修正并发标记阶段标记不全的问题。
  4. 并发清除(Concurrent Sweep)

    • 在并发清除阶段,CMS 会清理那些没有被标记为存活的垃圾对象。
    • 这个阶段是并发执行的,应用程序线程可以继续运行。

优点 并发收集,低停顿

不足

  • 吞吐量低:CMS追求用户线程停顿时间少,停顿时间少就只能与用户线程并发执行部分阶段,导致整个垃圾回收需要执行的整体时间会更长(停顿之后专心垃圾收集肯定是最快的),所以吞吐量会降低
  • 浮动垃圾问题:并发清除阶段,由于gc线程是与用户线程并发的,这个期间用户还会产生新的垃圾,所以一般会预留出一部分内存,不能等到老年代快满的时候才去收集,如果预留的内存不足以存放这部分浮动垃圾的话,就会出现Concurrent ModeFailure。出现这个错误之后,虚拟机将临时启用 Serial Old 来替代 CMS
  • 使用标记-清除算法:因为没有整理的过程,所以垃圾收集完之后,会有很多空间碎片,导致需要分配大块连续内存的时候,空间不足

7. G1 收集器

Garbage First(简称G1)收集器,意为垃圾优先,哪一块的垃圾最多就优先清理它。从名字就可以看出G1的一个特性,那就是G1能对不同区块的内存进行回收价值和成本排序,即价值越高成本越低的区块会被先回收。另外我们还能为G1设定性能指标,例如任意 1秒内暂停时间不超过 10 毫秒,G1会尽力去达成这个目标。

开创了收集器面向局部收集的设计思路和基于Region的内存布局形式。JDK8 Update 40这个版本以后的G1收集器被Oracle官方称为“全功能的垃圾收集器”。JDK 9发布之 日,G1宣告取代Parallel Scavenge加Parallel Old组合,成为服务端模式下的默认垃圾收集器。

G1依然还是采用了分代设计,但是之前的一些垃圾收集器有很大差别,不会在为新生代,老年代等分配规定大小的区域,而是将整个堆分成一个个大小固定的Region区域每一个Region都可以是新生代,老年代,Eden空间,Survivor空间的角色。所以Region成为了垃圾收集的最小单元,每一次回收都会是Region的整数倍大小。

  • 初始标记:仅仅只是标记一下GC Roots能直接关联到的对象。(需要停顿)
  • 并发标记:从GC Roots开始进行可达性分析,完成对象图的扫描,判断存活对象和可回收对象。做后再处理下SATB记录的有引用变动的对象(无需停顿)
  • 最终标记:对用户线程做另一个短暂的停顿,用于处理并发阶段结束后仍遗留 下来的最后那少量的SATB记录。(需要停顿)
  • 筛选回收:统计各个Region的回收价值和成本并进行排序,根据用户所期望的停顿时间来制定回收计划,筛选任意多个Region构成回收集,然后把决定回收的那一部分Region的存活对象复制到空的Region中,再清理掉整个旧 Region的全部空间。(需要停顿) 

总结:

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SOME/IP服务接口

本系列文章将分享我在学习 SOME/IP 过程中积累的一些感悟,并结合 SOME/IP 的理论知识进行讲解。主要内容是对相关知识的梳理,并结合实际代码展示 SOME/IP 的使用,旨在自我复习并与大家交流。文中引用了一些例图,但由于未能找到原作…

编写0号中断的处理程序

实验内容、程序清单及运行结果 编写0号中断的处理程序(课本实验12) 解: assume cs:code code segment start: mov ax,cs mov ds,ax mov si,offset do mov ax,0 mov es,ax mov di,200h mov cx,offset doend-offset do ;安装中断例…

Android系统开发(十五):从 60Hz 到 120Hz,多刷新率进化简史

引言 欢迎来到“帧率探索实验室”!今天,我们要聊聊 Android 11 中对多种刷新率设备的支持。你可能会问:“这和我写代码有什么关系?”别急,高刷新率不仅仅让屏幕更顺滑,还会直接影响用户体验。想象一下&…

基于JAVA的微信点餐小程序设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导,欢迎高校老师/同行前辈交流合作✌。 技术范围:SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容:…

ChatGPT结合Excel辅助学术数据分析详细步骤分享!

目录 一.Excel在学术论文中的作用✔ 二.Excel的提示词✔ 三. 编写 Excel 命令 四. 编写宏 五. 执行复杂的任务 六. 将 ChatGPT 变成有用的 Excel 助手 一.Excel在学术论文中的作用✔ Excel作为一种广泛使用的电子表格软件,在学术论文中可以发挥多种重要作用&a…

国内有哪些著名的CRM系统提供商?

嘿,你有没有想过,在这个信息爆炸的时代里,企业怎么才能更好地管理客户关系呢?答案就是使用高效的CRM系统。今天我就来给大家聊聊那些在国际上非常有名的CRM系统提供商吧。 悟空CRM 首先不得不提的就是悟空CRM了!这可…

Linux中的几个基本指令(二)

文章目录 1、cp指令例一:例二:例三:例四:例五: 2、mv 指令例一:例二: 3、cat指令例一: 4、tac指令5、which指令6、date指令时间戳:7、zip指令 今天我们继续学习Linux下的…

mock可视化生成前端代码

介绍:mock是我们前后端分离的必要一环、ts、axios编写起来也很麻烦。我们就可以使用以下插件,来解决我们的问题。目前支持vite和webpack。(配置超级简单!) 欢迎小伙伴们提issues、我们共建。提升我们的开发体验。 vi…

9. 神经网络(一.神经元模型)

首先,先看一个简化的生物神经元结构: 生物神经元有多种类型,内部也有复杂的结构,但是可以把单个神经元简化为3部分组成: 树突:一个神经元往往有多个树突,用于接收传入的信息。轴突:…

Web 音视频(二)在浏览器中解析视频

前言 浏览器中已经能直接播放视频,为什么还需要手动写代码解析? 因为,某些场景需要对视频进行更细致的处理,比如截取关键帧、提取视频中的文字、人物打码、极低延时播放视频等等。 总之,除了最单纯的视频播放外&…

ETLCloud在iPaas中的是关键角色?

在当今的数字化时代,企业越来越依赖于其处理和分析数据的能力。为了实现这一目标,企业需要将各种异构的应用和数据源集成在一起,形成一个统一的数据视图。在这一过程中,ETL(Extract, Transform, Load)和iPa…

以太网实战AD采集上传上位机——FPGA学习笔记27

一、设计目标 使用FPGA实现AD模块驱动采集模拟电压,通过以太网上传到电脑上位机。 二、框架设计 数据位宽转换模块(ad_10bit_to_16bit):为了方便数据传输,数据位宽转换模块实现了将十位的 AD 数据转换成十六位&#…

YOLOv1、YOLOv2、YOLOv3目标检测算法原理与实战第十三天|YOLOv3实战、安装Typora

1.学习哔哩哔哩《YOLOv1、YOLOv2、YOLOv3目标检测算法原理与实战》 炮哥带你学视频链接 第5章 YOLOv3实战 5.1 YOLOv3实战先导 5.2 pycharm与anaconda的安装 之前已经安装过了,见Pytorch框架与经典卷积神经网络与实战第一天|安装PyCharm&Anaconda&#xff0…

数据库SQLite和SCADA DIAView应用教程

课程简介 此系列课程大纲主要包含七个课时。主要使用到的开发工具有:SQLite studio 和 SCADA DIAView。详细的可成内容大概如下: 1、SQLite 可视化管理工具SQLite Studio :打开数据库和查询数据;查看视频 2、创建6个变量&#x…

YOLOv8改进,YOLOv8检测头融合DSConv(动态蛇形卷积),并添加小目标检测层(四头检测),适合目标检测、分割等

精确分割拓扑管状结构例如血管和道路,对各个领域至关重要,可确保下游任务的准确性和效率。然而,许多因素使任务变得复杂,包括细小脆弱的局部结构和复杂多变的全局形态。在这项工作中,注意到管状结构的特殊特征,并利用这一知识来引导 DSCNet 在三个阶段同时增强感知:特征…

Addressable学习

AssetsBundle是Unity的资源管理机制,将资源打包到AssetsBundle资源包并提供接口能从ab包里面加载资源出来。有了这个机制以后,我们要做资源管理,还需要做: a: 根据项目需求,编写编辑器扩展,提供指定资源打入对应bundle包工具策略; b: 根据项目的需求,资源…

概率密度函数(PDF)分布函数(CDF)——直方图累积直方图——直方图规定化的数学基础

对于连续型随机变量,分布函数(Cumulative Distribution Function, CDF)是概率密度函数(Probability Density Function, PDF)的变上限积分,概率密度函数是分布函数的导函数。 如果我们有一个连续型随机变量…

深入解析:Docker 容器如何实现文件系统与资源的多维隔离?

目录 一、RootFs1. Docker 镜像与文件系统层2. RootFs 与容器隔离的意义 二、Linux Namespace1. 进程命名空间1.1 lsns 命令说明1.2 查看“祖先进程”命名空间1.3 查看当前用户进程命名空间 2. 容器进程命名空间2.1 查看容器进程命名空间列表2.2 容器进程命名空间的具体体现 三…

深度学习|表示学习|卷积神经网络|由参数共享引出的特征图|08

如是我闻: Feature Map(特征图)的概念与 Parameter Sharing(参数共享)密切相关。换句话说,参数共享是生成 Feature Map 的基础。Feature Map 是卷积操作的核心产物,而卷积操作的高效性正是由参数…

【Linux网络编程】传输层协议

目录 一,传输层的介绍 二,UDP协议 2-1,UDP的特点 2-2,UDP协议端格式 三,TCP协议 3-1,TCP报文格式 3-2,TCP三次握手 3-3,TCP四次挥手 3-4,滑动窗口 3-5&#xf…