七大经典垃圾回收器篇+部分调优 不会让你失望(两万字)【图文】

本文章耗费十天写完,请大家认真看完,面试就差不多了,建议用电脑看。

一、垃圾回收器分类

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

(1)串行回收指的是在同一时间段内只允许有一个CPU用于执行垃圾回收操作,此时工作线程被暂停,直至垃圾收集工作结束。

➢在诸如单CPU处理器或者较小的应用内存等硬件平台不是特别优越的场合,串行回收器的性能表现可以超过并行回收器和并发回收器。所以,串行回收默认被应用在客户端的Client模式下的JVM中。64位系统默认就是Service模式。

➢在并发能力比较强的CPU上,并行回收器产生的停顿时间要短于串行回收器。

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

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

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

(2)独占式垃圾回收器(Stop the world)一旦运行,就停止应用程序中的所有用户线程,直到垃圾回收过程完全结束。
在这里插入图片描述
3、按碎片处理方式分,可分为压缩式垃圾回收器和非压缩式垃圾回收器。

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

再分配对象空间使用:指针碰撞

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

再分配对象空间使用:空闲列表

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

二、评估GC的性能指标

1、吞吐量:运行用户代码的时间占总运行时间的比例
➢(总运行时间:程序的运行时间+内存回收的时间)

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

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

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

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

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

简单来说,主要抓住两点:➢吞吐量 ➢暂停时间

三、吞吐量 VS 暂停时间

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

比如:虚拟机总共运行了100分钟, 其中垃圾收集花掉1分钟,那吞吐量就是99%。

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

吞吐量优先,意味着在单位时间内,STW的时间最短: 0.2 + 0.2 = 0.4
在这里插入图片描述
2、高吞吐量较好因为这会让应用程序的最终用户感觉只有应用程序线程在做“生产性”工作。直觉上,吞吐量越高程序运行越快。

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

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

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

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

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

四、垃圾回收器发展史

有了虚拟机,就一定需要收集垃圾的机制,这就是Garbage Collection,对应的产品我们称为Garbage Collector。
1999年随JDK1.3.1起来的是串行方式的Serial GC,它是第一款GC。ParNew垃圾收集器是Serial收集器的多线程版本
2002年2月26日,Parallel GC和Concurrent Mark Sweep GC跟随JDK1 .4.2起发布
Parallel GC在JDK6之后成为HotSpot默认GC。
2012年,在JDK1. 7u4版本中,G1可用。
2017年,JDK9中G1变成默认的垃圾收集器,以替代CMS。
2018年3月,JDK10中G1垃圾回收器的并行完整垃圾回收,实现并行性来改善最坏情况下的延迟。
2018年9月,JDK11发布。引入Epsilon垃圾回收器,又被称为"No-0p (无操作) "回收器。同时,引入ZGC:可伸缩的低延迟垃圾回收器(Experimental)。
2019年3月,JDK12发布。增强G1,自动返回未用堆内存给操作系统。同时,引入Shenandoah GC: 低停顿时间的GC(Experimental)。
2019年9月,JDK13发布。增强ZGC,自动返回未用堆内存给操作系统。
2020年3月,JDK14发布。删除CMS垃圾回收器。扩展ZGC在macOS和Windows上的应用

五、七大经典的垃圾回收器

1、串行回收器: Serial、Serial 0ld
并行回收器: ParNew、 Parallel Scavenge、Parallel 0ld
并发回收器: CMS、G1

在这里插入图片描述
2、新生代收集器: Serial、ParNew、 Parallel Scavenge
老年代收集器: Serial 0ld、Parallel 0ld、 CMS
整堆收集器: G1

3、垃圾收集器的组合关系
在这里插入图片描述
4、上图的解释:
(1)两个收集器间有连线,表明它们可以搭配使用:
Serial/Serial 01d、Serial/CMS、 ParNew/Serial 01d、 ParNew/CMS、Paral1el Scavenge/Serial 01d、Paral1el Scavenge/Parallel 01d、G1;

(2)其中Serial 01d作为CMS出现"Concurrent Mode Failure" 失败的后备预案。

(3) (红色虚线)由于维护和兼容性测试的成本,在JDK 8时将Serial+CMS、ParNew+Serial 01d 这两个组合声明为废弃(JEP 173) ,并在JDK 9中完全取消了这些组合的支持(JEP214) ,即:移除

(4) (绿色虚线)JDK 14中:弃用Parallel Scavenge和Serial old GC组合(JEP366 )

(5) (青色虚线)JDK 14中:删除CMS垃圾回收器(JEP 363 )

5、查看JDK不同版本使用的垃圾回收器

(1)方式一:设置参数:-XX:+PrintCommandLineFlags(我截图中少了一个加号+)
在这里插入图片描述
结论:JDK 1.8 默认采用的是ParallelGC(新生代),老年代默认就是Parallel old 了

  • 5
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值