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

垃圾回收器

一、GC分类与性能指标

1.垃圾回收器概述:

垃圾收集器没有在规范中进行过多的规定,可以由不同的厂商、不同版本的JVM来实现。

由于JDK的版本处于高速迭代过程中,因此Java发展至今已经衍生了众多的GC版本。

从不同角度分析垃圾收集器,可以将GC分为不同的类型:

按线程数分,可以分为串行垃圾回收器和并行垃圾回收器

串行回收指的是在同一时间段内只允许有一个CPU用于执行垃圾回收操作此时工作线程被暂停,直至垃圾收集工作结束:在诸如单CPU处理器或者较小的应用内存等硬件平台不是特别优越的场合,串行固收器的性能表现可以超过并行回收器和并发回收器。所以,串行回收默认被应用在客户端的client模式下的JVM中;在并发能力比较强的CPU上,并行回收器产生的停顿时间要短于串行回收器。

和串行回收相反,并行收集可以运用多个CPU同时执行垃圾回收,因此提升了应用的吞吐量,不过并行回收仍然与串行回收一样,采用独占式,使用了“Stop-the-world”机制。

按照工作模式分,可以分为并发式垃圾回收器和独占式垃圾回收器:

并发式垃圾回收器与应用程序线程交替工作,以尽可能减少应用程序的停顿时间

独占式垃圾回收器(stop the world)一旦运行,就停止应用程序中的所有用户线程,直到垃圾回收过程完全结束。

按碎片处理方式分,可分为压缩式垃圾回收器和非压缩式垃圾回收器:

压缩式垃圾回收器会在回收完成后,对存活对象进行压缩整理,消除回收后的碎片。

非压缩式的垃圾回收器不进行这步操作

按工作的内存区间分,又可分为年轻代垃圾回收器和老年代垃圾回收器

2.评估GC的性能指标:

吞吐量:运行用户代码的时间占总运行时间的比例

垃圾收集开销:吞吐量的补数,垃圾收集所用时间与总运行时间的比例

暂停时间:执行垃圾收集时,程序的工作线程被暂停的时间

收集频率:相对于应用程序的执行,收集操作发生的频率

内存占用:Java 堆区所占的内存大小

快速:一个对象从诞生到被回收所经历的时间

暂停时间的重要性日益凸显。因为随着硬件发展,内存占用多些越来越能容忍,硬件性能的提升也有助于降低收集器运行时对应用程序的影响,即提高了吞吐量。而内存的扩大,对延迟反而带来负面效果。

主要关注吞吐量和暂停时间

3.吞吐量:

吞吐量就是CPU用于运行用户代码的时间与CPU总消耗时间的比值,即吞吐量=运行用户代码时间/(运行用户代码时间+垃圾收集时间)

这种情况下,应用程序能容忍较高的暂停时间,因此,高吞吐量的应用程序有更长的时间基准,快速响应是不必考虑的。

吞吐量优先,意味着在单位时间内,STW的时间最短

4.暂停时间:

"暂停时间”是指一个时间段内应用程序线程暂停,让GC线程执行的状态

暂停时间优先,意味着尽可能让单次STW的时间最短

高吞吐量较好因为这会让应用程序的最终用户感觉只有应用程序线程在做“生产性”工作。直觉上,吞吐量越高程序运行越快。

低暂停时间(低延迟)较好因为从最终用户的角度来看不管是GC还是其他原因导致一个应用被挂起始终是不好的。这取决于应用程序的类型,有时候甚至短暂的288毫秒暂停都可能打断终端用户体验。因此,具有低的较大暂停时间是非常重要的,特别是对于一个交互式应用程序。

不幸的是”高吞吐量”和”低暂停时间”是一对相互竞争的目标(矛盾):

因为如果选择以吞吐量优先,那么必然需要降低内存回收的执行频率,但是这样会导致GC需要更长的暂停时间来执行内存回收;

相反的,如果选择以低延迟优先为原则,那么为了降低每次执行内存回收时的暂停时间,也只能频繁地执行内存回收,但这又引起了年轻代内存的缩减和导致程序吞吐量的下降。

在设计(或使用)GC算法时,我们必须确定我们的目标:一个GC算法只可能针对两个目标之一(即只专注于较大吞吐量或最小暂停时间),或尝试找到一个二者的折衷;

现在标准:在最大吞吐量优先的情况下,降低停顿时间。

二、不同的垃圾回收器的概述:

串行回收器:Serial、Serial old

并行回收器:ParNew、Parallel Scavenge、Parallel old

并发回收器:CMS、G1

1.垃圾回收器和分代之间的关系:

新生代收集器:Serial、ParNew、Parallel Scavenge

老年代收集器:Serial Old、Parallel Old、CMS

整堆收集器:G1

组合关系:

 

相关文章:

  • Spring——Spring开发实战经验(1)
  • trl-强化学习训练-grpo训练为例
  • 网络接收的流程理解
  • [NKU]C++基础课(二)--- externC、强制类型转换、类与对象、面向对象程序设计语言、对象创建和使用、类的定义、封装
  • java死锁
  • 轮子项目--消息队列的实现(4)
  • openharmony系统移植之显示驱动框架从framebuffer升级为drm(linux-5.10)
  • 【Java】—— 包装类泛型
  • 【go语言规范】关于接口设计
  • 财务系统的开发需要注意哪些东西
  • Java-数据结构基础1
  • 【办公类-90-02】】20250215大班周计划四类活动的写法(分散运动、户外游戏、个别化综合)
  • LeeCode题库第十九题
  • 「软件设计模式」适配器模式(Adapter)
  • 使用 Ansys Fluent 进行电池热滥用失控传播仿真
  • 算法思考:位运算
  • CNN手写数字识别1——模型搭建与数据准备
  • 【C语言】移除元素
  • 代码随想录算法【Day47】
  • 解决`Illegal group reference: group index is missing`的两种方式
  • 九家企业与上海静安集中签约,投资额超10亿元
  • 苹果Safari浏览器上的搜索量首次下降
  • 欧派家居:一季度营收降4.8%,目前海外业务整体体量仍较小
  • 一季度全国消协组织为消费者挽回经济损失23723万元
  • 吴清稳市场稳预期发布会十要点:谈平准基金、股市稳定、公募改革和巴菲特
  • 又一日军“慰安妇”制度受害者去世,大陆登记在册幸存者仅剩7人