JDK1.8默认的垃圾回收器Parallel GC(Throughput GC)

JVM1.8默认的垃圾回收器Parallel GC(Throughput GC)

Paraller

Parallel是一种多线程的垃圾回收器,他主要的目标就是最大化吞吐量(吞吐量是值应用程序实际执行代码的时间相对于总时间(包括垃圾回收时间))的比例。Parallel GC在老年代和新生代垃圾回收会使用多线程执行。

新生代

新生代使用的是复制算法。

老年代

老年代采用的是MSC回收算法

MSC (Mark-Sweep-Compact)

Marking 标记

在标记就单,垃圾回收器回遍历堆中的所有对象,识别出来哪些对象是可达的。并且将这些活跃的对象标记为活跃的伙计。这个过程通常是通过(GC Roots,通常是静态变量、栈中的引用等)开始进行的。

Sweeping 清除

在清除阶段,垃圾回收器回扫描堆中的没有被标记的对象,将这些对象从内存中释放,一边以后可以分配给新的对象。这一步只会简单清楚不可达的对象,不会对内存进行整理。因此可能导致内存碎片化的问题。

Compacting 压缩

压缩阶段可以解决内存碎片化的问题。在清除阶段之后,堆中可能出现碎片,这些碎片会导致内存分配不连续和低效。

工作流程

标记阶段:首先,标记所有存活的对象。

清除阶段:接着,清除所有未标记的对象,将它们的内存回收。

压缩阶段:最后,压缩存活的对象,将它们集中到堆的一端,释放出连续的可用内存。

优点缺点

优点

可以有效地回收内存并减少内存碎片,然后后续的内存分配更加高效。

适合老年代,因为老年代中对象存活率较高。内存碎片可能更为严重。

缺点

MSC可能会导致比较长时间的Stop-the-world(STW)停顿。因为压缩过程中,整个堆中的所有对象都可能需要移动。

开销比较大:压缩阶段需要复制和移动大量的对象,这增加了垃圾回收的开销。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哇塞大嘴好帅(DaZuiZui)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值