【JVM】垃圾回收器概述

垃圾回收器概述

分类

  1. 按照线程数:串行 & 并行 垃圾回收器
  • 串行回收指的是在同一时间段内只允许有一个CPU用于执行垃圾回收操作,此时工作线程被暂停,直至垃圾收集工作结束。

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

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

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

  1. 按照工作模式分类:并发式 & 独占式
  • 并发式垃圾回收器与程序交替工作, 以尽可能减少程序停顿时间
  • 独占式垃圾回收器一旦运行, 就停止程序所有的用户线程,直到结束
  1. 按照碎片处理方式:压缩式 & 非压缩式
  2. 按照工作内存区域:年轻代 & 老年代

性能指标

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

    • (总运行时间:程序的运行时间+内存回收的时间)
  • 垃圾收集开销:吞吐量的补数,垃圾收集所用时间与总运行时间的比例。

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

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

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

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

经典垃圾回收器

  • 串行回收器: Serial、Serial Old

  • 并行回收器: ParNew、 Parallel Scavenge、 Parallel Old

  • 并发回收器: CMS、 G1

image-20200518143727788

组合关系

image-20200518143755248

  1. 两个收集器间有连线,表明它们可以搭配使用:
    Serial/Serial Old、
    Serial/CMS、
    ParNew/Serial Old、
    ParNew/CMS、
    Paral1el Scavenge/Serial Old、
    Parallel Scavenge/Parallel Old、
    G1

  2. 其中Serial Old作为CMS出现"Concurrent Mode Failure"失败的后备预案。

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

  4. (绿色虚线)JDK 14中:弃用Parallel Scavenge和Seria1Old GC组合(JEP 366 )

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值