JVM的垃圾回收Serial、Serial Old、Parallel Scavenge、Parallel Old的介绍和STW(Stop The World)

本文介绍了JVM的垃圾回收器,包括Serial和Serial Old,它们分别在年轻代和老年代使用标记-复制和标记-整理算法,且为单线程。Serial Old与Serial配合使用时,会导致Stop The World (STW)现象。另外,还探讨了Parallel Scavenge和Parallel Old这对多线程垃圾回收器,它们通过减少STW停顿时间来提高性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述

Serial和Serial Old

JDK诞生的第一组垃圾回收器就是Serial和Serial Old。

Serial工作在年轻代,使用标记-复制的回收算法,它是单线程的垃圾回收器
Serial Old工作在老年代,使用标记-整理的回收算法,它也是单线程的垃圾回收器

使用Serial+Serial Old:-XX:+UseSerialGC=Serial+SerialOld

当垃圾回收器工作时所有业务线程都会停止运行,也就是说业务线程工作一段时间垃圾回收工作一段时间,这个业务线程停顿的过程就是STW

在这里插入图片描述

Parallel Scavenge和Parallel Old

由于Parallel Scavenge和Parallel Old经常一起使用,也被简称为PS+PO,JDK默认的垃圾回收器组合就是这个。

Parallel Scavenge简称PS,使用标记-复制的回收算法,它是多线程的垃圾回收器
Parallel Old简称PO,使用标记-整理的回收算法,它也是多线程的垃圾回收器

使用PS+PO:-XX:+UseParallelGC=ParallelScavenge+ParallelOld

PS+PO和Serial+Serial Old的取别在于PS+PO是多线程的垃圾回收器,减少了STW的停顿时间

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值