经典垃圾回收器

news2025/2/24 11:04:17

Serial收集器

Serial 是一种新生代的收集器。顾名思义“serial 串行”,它是一种单线程工作的收集器,它的“单线程”并不仅仅指的只有一个处理器或一个线程来实现垃圾的收集工作,更重要的是他在垃圾收集的过程中会暂停所有的用户线程(STW),直到它收集结束。

Serial/Serial Old收集器运行示意图:(Serial Old 收集器是Serial 的老年代版本,后面会提到)

Serial 新生代收集器它采用的是标记-复制的算法,并且在垃圾收集的时候会进行STW,暂停所有的用户线程。


ParNew收集器

ParNew收集器实质上是Serial收集器的多线程并行版本,可以同时使用多条线程进行并行垃圾收集,除此之外,与Serial 收集器相比并没有太多的创新之处。

ParNew/Serial Old收集器运行示意图:

 

和Serial 收集器一样,也采用的是标记-复制算法进行新生代的垃圾收集

注意:ParNew收集器在单核心处理器的环境中绝对不会有比Serial 收集器更好的效果(存在线程的上下文切换)


Parallel Scavenge 收集器

Parallel Scavenge 收集器也是一款新生代的收集器,同样是基于标记-复制算法实现,也是能够并行收集的多线程收集器,那它相对于ParNew 收集器有什么特别之处呢?

Parallel Scavenge 它的关注点是尽可能的达到一个可控制的吞吐量

它提供了两个参数用于精确的控制吞吐量:-XX:MaxGCPauseMillis:控制最大垃圾收集的停顿时间  -XX:GCTimeRatio :直接设置吞吐量大小

-XX:MaxGCPauseMillis并不是简单的只要设置了最大停顿时间就能使得垃圾回收更快,垃圾收集停顿时间是以牺牲吞吐量的新生代空间为代价换取的:系统把新生代调的小一些,垃圾回收自然就快了,这也导致垃圾回收的次数增加,原来10秒收集一次,每次收集100ms,现在五秒收集一次,每次停顿70ms,吞吐量也下来了。

Parallel Scavenge 也可以设置自适应调节策略:虚拟机会根据当前系统的运行情况收集性能监控信息,动态调整一些参数以提供最合适的停顿时间或者最大的吞吐量。


Serial Old收集器

Serial Old 是Serial收集器的老年代版本,同样是一个线程进行垃圾收集,采用标记-整理算法。


Parallel Old收集器

Parallel Old收集器是Parallel Scavenge 收集器的老年代版本,支持多线程并发收集,基于标记-整理算法实现。只有Parallel  Old出现以后,Parallel Scavenge新生代收集器才与之配合使用,“吞吐量优先”才算是名副其实,因为之前除了Serial Old这种单线程老年代的收集器之外,没有其他能和Parallel Scavenge收集器配合进行垃圾收集,(CMS无法和他配合工作)。

Parallel Scavenge/Parallel Old收集器运行示意图:


CMS收集器

CMS 收集器(Concurrent Mark Sweep)是一种以获取最短停顿时间位目标的老年代收集器。是基于标记-清除算法(不同于之前几款老年代收集器)实现的。

CMS 收集过程包含四个部分:

  1. 初始标记
  2. 并发标记
  3. 重新标记
  4. 并发清除

运行过程示意图

初始标记阶段只是标记一下GC Roots能直接关联到的对象,速度很快,需要进行STW,只不过这个STW时间很短;并发标记阶段就是从GC Roots的直接关联对象开始遍历整个对象图的过程,比较耗时但是不会进行STW,会和用户线程并发执行;重新标记阶段,并发标记阶段由于用户线程和垃圾收集线程并发运行,导致用户线程运行期间对象图的结构发生变化,可能导致漏标、多标的情况;重新标记阶段就是针对这些情况进行重新标记(采用增量更新的方式),需要进行STW(不然对象图结构一直变化,会一直存在漏标、多标的问题),时间也不会很长;最后进行并发清除。

由于最后的垃圾清除也是用户线程和垃圾收集线程并发运行,所以用户线程再这一时间段内也会产生垃圾,这些垃圾成为“浮动垃圾”,用于并发标记阶段已结束,只能等到下一次GC时进行标记收集。

最后用于线程和垃圾收集线程之所以能并发运行的原因也是因为CMS 是基于标记-清除算法实现的,不会涉及到对象的移动。像标记-整理算法涉及到对象的移动,必须进行STW.

CMS存在的问题:

  1. 由于CMS收集器无法处理“浮动垃圾”,当CMS的垃圾收集速度赶不上浮动垃圾产生的速度时,会出现“Concurrent Mode Failure”并发失败,而不得不进行STW(不进行STW的话会一直有浮动垃圾生成)的Full gc.
  2. 同样也是因为垃圾收集阶段用户线程也要运行,所以就必须预留一些空间给用户线程使用,(一般CMS不会等到老年代快要满的时候才进行收集,JDK5默认68%)如果预留的空间不足以放下用户线程再垃圾收集阶段产生的新对象时,就会时出现“Concurrent Mode Failure”并发失败,这时虚拟机将不得不采用后备案:临时启用Serial Old进行老年代收集。
  3. 由于采用标记清除算法,会导致收集结束会有大量的内存碎片,会给大对象的空间分配造成很大麻烦,当大对象没有足够大的连续空间分配时,不得不提前进行Full GC。
  4. CMS的重新标记阶段采用的是“增量更新”的方式(增量更新:当黑色对象插入新的指向白色对象的引用关系时,会对此黑色对象进行记录,并发标记结束后,对这些黑色对象再进行一次深度标记。)这也可能会导致STW时间过长,增加系统响应时间。

G1 收集器

它开创了收集器面向局部收集的思路和基于Region的内存布局形式。之前的收集器要么面向新生代(Minor GC),要么面向老年代(Major GC/Old GC),要么就是整个Java堆(Full GC)。而G1则是面向堆内任何部分来组成垃圾“回收集”进行回收,衡量标准不再是哪个分代,而是那块内存中存放的垃圾数量最多,回收收益最大,就是G1收集器的Mixed GC模式。

G1之所以能实现以上,就是实现了基于Region的堆内存布局。

G1把Java堆划分为多个大小相等的独立的区域(Region),每一个Region都可以根据需要,扮演新生代的Eden、Survivor,或是老年代。

Region中还有一类特殊的Humongous区域,专门来存储大对象。

G1收集器的运行过程

  1. 初始标记:仅仅标记GC Roots能直接关联到的对象
  2. 并发标记:从GC Roots能直接关联到的对象开始对堆中的对象进行可达性分析
  3. 最终标记:类似于CMS的重新标记,只不过G1采用的时原始快照的方式
  4. 筛选回收:最后的垃圾回收并不会像CMS收集器那样对所有未标记的垃圾对象进行回收。再G1中,这一步会负责更新Regoin的统计数据,对每个Region的回收价值的成本进行排序,根据用户所期望的停顿时间来制定回收计划,可以自由选择任意多个Regio构成回收集,然后把回收集中的Region中的存活对象赋值到空的Region中,再清理掉整个旧Region的全部空间。(这里的赋值会涉及到对象的移动,所以是必须暂停用户线程的,由多条垃圾线程并发完成)

G1如何解决跨Region引用问题?

每个Region中都维护了一个记忆集,记忆集中记录着其他Region指向该Region的跨Region引用,并标记这些引用分别在哪些卡页(内存块)范围之内。

G1在并发标记阶段如何保证收集线程与用户线程互不干扰的运行?

首先,在并发标记阶段由于用户线程的运行,产生的多标、漏标,G1时使用原始快照(STAB)的方式解决的(CMS 是使用增量更新的方式解决)。

对于用户线程运行过程中产生的新对象的内存分配所需的空间,在每个Region中维护了两个名为TAMS的指针,把Region中的一部分空间划分出来用于并发标记阶段中产生的新对象(G1的最后的筛选回收阶段会进行STW,不会有新对象产生),新对象的地址必须在这两个指针位置以上。(这两个指针以上的地址默认被标记过不会被回收)。和CMS 的类似,如果并发标记阶段太慢,导致垃圾回收的速度赶不上新对象内存分配的速度,G1也会被迫冻结用户线程,进行STW的Full gc。

怎样建立可靠的停顿预测模型?

G1收集器的停顿预测模型是以”衰减均值“(可以理解为一种特殊的平均值,比普通的平均值更易受到新数据的影响,能更准确的代表每个Region的”最近的“平均状态)为理论基础来实现的在垃圾收集过程中,G1收集器会记录每个Region的回收耗时、每个Region记忆集的脏卡数量等各个可测量的步骤花费的成本,并分析出平均值、标准偏差、置信度等统计信息。然后通过这些信息预测现在开始回收的话,由哪些Region组成的会收集可以在不超过期望停顿时间的约束下获得最高的收益。


《深入理解Java虚拟机》垃圾回收的一个总结。

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

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

相关文章

算法通过村第九关-二分(中序遍历)黄金笔记|手撕二分

文章目录 前言1. 基本查找2. 二分查找与分治2.1 循环的方式2.2 递归的方式 3. 元素中的重复的二分查找总结 前言 提示:有些人,远看是灯塔,靠近是悬崖。 --任明信《别人》 二分查找是非常重要的算法之一,不仅要掌握,更要…

印章篆刻小程序商城的作用是什么

印章的需求度也有很高市场需求,处理办公印章外,还有艺术类的,而对爱好者来说,需要找到一家靠谱的品牌制作,包括材料、样式、内容等都有较高要求,线上可以接触到更多雕刻商家。 而对品牌来说,需…

常见应用层协议

一.HTTP(超文本传输协议) HTTP 和 HTTPS 二.FTP(文件传输协议) 三.SMTP(简单邮件传输协议) 四.POP3(邮局协议版本3) 五.IMAP(互联网消息访问协议) 六.DNS&am…

GitHub 基本操作

目录 1、创建库 2、上传项目 3、获取token 4、 删除库 1、创建库 登录github,点击“Create repository”创建库,点击右上方绿色的“New”,Repository name处填写你的项目名,可选“Add a README file"默认创建一个说明文…

基于SSM的保险业务管理系统设计与实现

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:采用JSP技术开发 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目&#x…

480万商品,如何架构商品治理平台?

说在前面 在40岁老架构师 尼恩的读者交流群(50)中,很多小伙伴拿高薪,完成架构的升级,进入架构师赛道,打开薪酬天花板。 最近有小伙伴拿到了一线互联网企业如京东、网易、微博、阿里、汽车之家、极兔、有赞、希音、百度、滴滴的架…

Fortinet 2023上半年全球威胁态势研究报告:勒索软件检测成下降趋势,针对性攻击持续升温

近日,专注于推动网络与安全融合的全球网络安全领导者Fortinet(NASDAQ:FTNT),发布《2023上半年全球威胁态势研究报告》。报告显示,2023 年上半年勒索软件检出数量继续下降、高级持续性威胁(APT&a…

机器人中的数值优化|【六】线性共轭梯度法,牛顿共轭梯度法

机器人中的数值优化|【六】线性共轭梯度法,牛顿共轭梯度法 往期回顾 机器人中的数值优化|【一】数值优化基础 机器人中的数值优化|【二】最速下降法,可行牛顿法的python实现,以Rosenbrock function为例 机器人中的数值优化|【三】无约束优化…

Spring Boot 3.0:构建下一代Java应用的新方法

文章目录 Spring Boot 3.0:一览1. **模块化应用程序**2. **更强大的自动化工具**3. **更强大的安全性**4. **更好的性能和扩展性** 如何开始使用Spring Boot 3.01. 安装Spring Boot CLI2. 创建新项目3. 配置应用程序4. 编写业务逻辑5. 测试应用程序6. 构建和部署 结…

DataGrip 恢复数据

DataGrip 恢复数据 准备数据库 create database chap02; use chap02;恢复数据 运行sql脚本方式恢复数据到刚刚创建的数据库 数据右键—> SQL Scripts —> Run SQL Script… 选择sql脚本

基本网络协议

TCP 协议 TCP 协议是一种传输控制协议,是一种面向连接的传输层协议,它提供高可靠性的通信高可靠性:数据无错误,数据无丢失,数据无失序,数据无重复到达。 TCP 协议头部结构 下图是 TCP 协议的头部结构,如图: 16 位端口号: 告知主机…

超声波乳化具有什么特点(优点)?

梵英超声(fanyingsonic)探针式超声波乳化棒 超声波乳化是通过探针式超声波探头,高强度超声波耦合到液体中并产生声空化。超声波或声空化产生高剪切力,提供将大液滴破碎成纳米尺寸液滴所需的能量。梵英超声(fanyingsonic)提供各种探头式超声波乳化棒和配件…

QT的安装和注册

浏览器搜索qt官网或者点链接直接跳转 Index of /new_archive/qthttps://download.qt.io/new_archive/qt/尽量下载5.6版本以上的 根据系统选择下载 进入qt官网 点击注册 在安装界面输入注册的账号 然后一直点击下一步 选择需要的组件 完成安装

基于springboot+vue的新闻推荐系统

目录 前言 一、技术栈 二、系统功能介绍 管理员模块的实现 用户信息管理 排行榜管理 新闻信息管理 用户模块的实现 首页信息 新闻信息 我的收藏 三、核心代码 1、登录模块 2、文件上传模块 3、代码封装 前言 随着信息互联网购物的飞速发展,国内放开了自…

MeterSphere 监控方案

前言:在部署MeterSphere之后,很多时候需要看下MeterSphere服务的监控信息,虽然有监控告警脚本,但还不是太直观,所以就结合 PrometheusExporterGrafana 部署一套完整的MeterSphere监控方案。 首先我们先罗列一下需要监控…

【工具使用】如何使用Audition创建多音轨项目并验证

一,简介 本文主要介绍如何使用Audition 2020创建多音轨工程,并新增轨道,供参考。 二,操作步骤 2.1 新建多轨工程 打开Audition,新建多轨会话: 设置参数,点击确定: 工程默认有6个…

MataDoor 模块化后门:先发现后解除

👁 PT 专家安全中心的专家发现了一个新的 Dark River 组织,该组织利用名为 MataDoor 的高科技模块化后门攻击国防工业公司。请阅读我们的最新研究。 我们的专家于 2022 年 10 月在调查一家俄罗斯工业企业的事件时首次遇到这种恶意软件。 🥷…

Javascript中生成器函数和Generator对象的介绍与使用

✨Generator 🎶Generator的描述 Generator 函数是ES6提供的一种异步编程解决方案 🎉三种异步方法出现的顺序 🍧Generator的 核心语法 // 像下面这样 func 这样的函数称之为生成器函数 // 通过 * 进行声明 通过yield进行等待 function* fu…

十六,镜面IBL--预滤波环境贴图

又到了开心的公式时刻了。 先看看渲染方程 现在关注第二部分,镜面反射。 其中 这里很棘手,与输入wi和输出w0都有关系,所以,再近似 其中第一部分,就是预滤波环境贴图,形式上与前面的辐照度图很相似&#…

TensorFlow入门(五、指定GPU运算)

一般情况下,下载的TensorFlow版本如果是GPU版本,在运行过程中TensorFlow能自动检测。如果检测到GPU,TensorFlow会默认利用找到的第一个GPU来执行操作。如果机器上有超过一个可用的GPU,除第一个之外的其他GPU默认是不参与计算的。如果想让TensorFlow使用这些GPU执行操作,需要将运…