JVM(五)——七种垃圾回收器

在 JVM 中,常见的七种垃圾回收器包括:

1、Serial 垃圾回收器(串行回收器)

  • 单线程执行垃圾回收,在进行垃圾回收时,会暂停所有用户线程。
  • 适用于小型应用和单核 CPU 环境。

2、ParNew 垃圾回收器

  • Serial 回收器的多线程版本。
  • 常用于与 CMS 回收器配合使用。

3、Parallel Scavenge 回收器

  • 关注的是吞吐量(运行用户代码的时间 / 总运行时间)。
  • 可以通过参数来调整垃圾回收的时间和频率。

4、Serial Old 回收器

  • Serial 回收器的老年代版本。

5、Parallel Old 回收器

  • Parallel Scavenge 回收器的老年代版本。

6、CMS(Concurrent Mark Sweep)回收器

  • 以获取最短回收停顿时间为目标,是一种并发的垃圾回收器。
  • 分为初始标记、并发标记、重新标记、并发清除四个阶段。

7、G1(Garbage-First)回收器

  • 面向服务端应用,将堆内存划分为多个大小相等的区域。
  • 可以预测停顿时间,并优先回收价值最大的区域。

例如,在一个对响应时间要求较高的 Web 应用中,可能会选择 CMSG1 回收器;而对于后台批量处理任务,更注重吞吐量,可能会选择 Parallel Scavenge 搭配 Parallel Old 回收器。

相关推荐
廋到被风吹走20 分钟前
【Spring】事务管理深度解析|从原理到实战
java·spring
1001101_QIA39 分钟前
C++多线程并发学习路线
jvm
lkbhua莱克瓦2443 分钟前
Java进阶——IO流
java·开发语言·笔记·学习方法·io流
韩立学长43 分钟前
【开题答辩实录分享】以《自选便利店商品分类管理系统》为例进行选题答辩实录分享
java·mysql·web
阿杰同学1 小时前
Java中55种锁,高级面试题,最新面试题
java·开发语言
清晓粼溪1 小时前
SpringCloud01-基础概念
java·开发语言·spring cloud
路边草随风1 小时前
java实现发布flink yarn application模式作业
java·大数据·flink·yarn
华仔啊1 小时前
RabbitMQ 如何保证消息不丢失和不重复消费?掌握这 4 个关键点就够了
java·后端·rabbitmq
隔山打牛牛1 小时前
击穿式理解“JAVA栈帧”
jvm
编程饭碗1 小时前
【Java循环】
java·服务器·算法