63.垃圾回收器的分类、GC性能指标、吞吐量与暂停时间对比

1.垃圾回收器的分类

  1. 按垃圾回收器的线程数分:分为串行和并行垃圾回收器。串行垃圾回收器只有一个垃圾回收线程,并行垃圾回收器有多个垃圾回收线程。需要注意的是:串行以及并行垃圾回收器在回收垃圾的时候,都会Stop the World
    在这里插入图片描述
    在这里插入图片描述
  2. 按工作模式分,分为并发式和独占式垃圾回收器。并发式指的是垃圾回收器线程和应用程序线程交替工作,尽可能的减少应用程序的停顿时间。独占式指的是停止用户线程,直到垃圾回收完成。
    在这里插入图片描述
  3. 按碎片处理方式分:分为压缩式和非压缩式垃圾回收器。压缩式指的是会对内存进行碎片整理;非压缩式指的是不对内存进行内存整理。对于经过内存碎片整理的空间,再分配对象空间的时候使用的是指针碰撞法;对于没有经过碎片整理的空间,再分配对象空间的时候使用的是空闲列表法。
  4. 按工作内存区间分:分为年轻代和老年代垃圾回收器。
    在这里插入图片描述

2.GC性能指标

  1. 主要注意标红的三个指标。
    在这里插入图片描述
  2. 总体上来看,随着技术的进步,三者的总体表现越来越好。
    随着内存的发展,占用更多的内存变得越来越能够容忍,这样一来,垃圾回收进行的次数少,程序运行时间就长,吞吐量就高;但是,当需要进行垃圾回收的时候,由于需要清理的对象太多,用户线程暂停的时间就会很长,延迟就会很高。
  3. 主要关注吞吐量和暂停时间。
    在这里插入图片描述

3.吞吐量和暂停时间对比

  1. 吞吐量:运行用户代码时间 / (运行用户代码时间 + 垃圾收集时间)
    在这里插入图片描述
  2. 暂停时间:用户线程暂停的时间
    在这里插入图片描述
  3. 对比
    吞吐量和暂停时间是相互矛盾的。
    追求高吞吐量,必然会降低内存回收的执行频率,但是这样,GC会需要更长的暂停时间来执行内存回收。
    追求低延迟,也就是低暂停时间,必然会频繁的执行内存回收,这样会降低吞吐量。因为用户线程执行的时间变少了。
    在这里插入图片描述
  4. 现代垃圾回收器设计只能针对较大吞吐量或最小暂停时间。现代表中:在最大吞吐量优先的情况下,降低停顿时间(在可控的停顿时间范围内,最大化吞吐量)。

更多JVM文章请访问我的JVM专栏:
https://blog.csdn.net/u011069294/category_10113093.html

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值