谈谈HotSpot JVM 中的不同垃圾回收器

简介: 【10月更文挑战第5天】理解 HotSpot JVM 中的不同垃圾回收器(如 CMS、G1 和 ZGC)的区别,需要深入了解它们的设计原理、工作方式和应用场景。以下是对这三个垃圾回收器的简要概述以及一个示例 Java 程序,虽然示例程序本身不能直接展示垃圾回收器的内部机制,但可以帮助观察不同垃圾回收器的行为。

理解 HotSpot JVM 中的不同垃圾回收器(如 CMS、G1 和 ZGC)的区别,需要深入了解它们的设计原理、工作方式和应用场景。以下是对这三个垃圾回收器的简要概述以及一个示例 Java 程序,虽然示例程序本身不能直接展示垃圾回收器的内部机制,但可以帮助观察不同垃圾回收器的行为。

垃圾回收器概述

  1. CMS (Concurrent Mark-Sweep)
  • 设计目标:最小化停顿时间,适合需要低延迟的应用。
  • 工作原理
  • 初始标记(Initial Marking):标记 GC Roots 能直接关联到的对象。
  • 并发标记(Concurrent Marking):并发标记可达对象。
  • 重新标记(Remark):修正并发标记期间的变化。
  • 并发清除(Concurrent Sweeping):并发清除未标记的对象。
  • 缺点:对内存碎片比较敏感,可能会因为无法找到连续空间而导致 Full GC。
  1. G1 (Garbage-First)
  • 设计目标:替代 CMS,实现可预测的低停顿时间,同时减少内存碎片。
  • 工作原理
  • 将堆划分为多个大小相同的区域(Region)。
  • 采用并发标记-整理算法(Mark-Compact),以尽量减少垃圾收集停顿时间。
  • 分为四个阶段:初始标记、并发标记、最终标记和筛选回收(Evacuation)。
  • 优点:更好地管理大堆内存,减少 Full GC 的发生。
  1. ZGC
  • 设计目标:实现几乎无停顿的垃圾回收,停顿时间不超过 10ms。
  • 工作原理
  • 采用着色指针(Colored Pointers)来追踪对象。
  • 并发进行所有的垃圾回收工作,几乎不需要停顿应用线程。
  • 支持超大堆内存,停顿时间与堆大小无关。
  • 优点:极低停顿时间,适合超大内存和低延迟应用。

示例 Java 程序

以下是一个简单的 Java 程序,可以用来观察不同垃圾回收器的行为。你可以通过 JVM 参数指定使用哪种垃圾回收器。

java复制代码
import java.util.ArrayList;  
import java.util.List;  
public class GCDemo {  
private static final int SIZE = 1000000;  
public static void main(String[] args) {  
        List<Object> objects = new ArrayList<>();  
// 创建大量对象  
for (int i = 0; i < SIZE; i++) {  
            objects.add(new Object());  
if (i % 100000 == 0) {  
                System.out.println("Created " + i + " objects.");  
// 模拟一些工作,帮助观察 GC 行为  
try {  
                    Thread.sleep(50);  
                } catch (InterruptedException e) {  
                    Thread.currentThread().interrupt();  
                }  
            }  
        }  
        System.out.println("All objects created.");  
// 保持程序运行一段时间,观察 GC 行为  
try {  
            Thread.sleep(5000);  
        } catch (InterruptedException e) {  
            Thread.currentThread().interrupt();  
        }  
        System.out.println("Program ends.");  
    }  
}

运行示例

使用不同的垃圾回收器运行这个程序,观察输出和性能:

  1. 使用 CMS
sh复制代码
java -XX:+UseConcMarkSweepGC -Xms512m -Xmx512m GCDemo
  1. 使用 G1
sh复制代码
java -XX:+UseG1GC -Xms512m -Xmx512m GCDemo
  1. 使用 ZGC
sh复制代码
java -XX:+UseZGC -Xms512m -Xmx512m GCDemo

观察和分析

通过 JVM 自带的日志(可以加上 -Xlog:gc* 参数来获取详细的 GC 日志),你可以观察到不同垃圾回收器的行为:

  • CMS 会显示初始标记、并发标记、重新标记和并发清除等阶段。
  • G1 会显示初始标记、并发标记、最终标记和筛选回收等阶段。
  • ZGC 会显示并发标记、并发整理等阶段,并且停顿时间非常短。

总结

不同的垃圾回收器有不同的设计目标和实现方式,选择合适的垃圾回收器对应用的性能至关重要。CMS 已经被标记为过时,G1 是目前的主流选择,而 ZGC 提供了极低停顿时间的垃圾回收解决方案,适合超大内存和极低延迟要求的应用。通过实际运行和观察日志,可以更好地理解它们的行为和特性。

相关文章
|
3月前
|
存储 算法 Oracle
极致八股文之JVM垃圾回收器G1&ZGC详解
本文作者分享了一些垃圾回收器的执行过程,希望给大家参考。
|
29天前
|
缓存 算法 Java
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
这篇文章详细介绍了Java虚拟机(JVM)中的垃圾回收机制,包括垃圾的定义、垃圾回收算法、堆内存的逻辑分区、对象的内存分配和回收过程,以及不同垃圾回收器的工作原理和参数设置。
54 4
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
|
27天前
|
存储 监控 算法
美团面试:说说 G1垃圾回收 底层原理?说说你 JVM 调优的过程 ?
尼恩提示: G1垃圾回收 原理非常重要, 是面试的重点, 大家一定要好好掌握
美团面试:说说 G1垃圾回收 底层原理?说说你 JVM 调优的过程  ?
|
4月前
|
存储 算法 Java
Java面试题:深入探究Java内存模型与垃圾回收机制,解释JVM中堆内存和栈内存的主要区别,谈谈对Java垃圾回收机制的理解,Java中的内存泄漏及其产生原因,如何检测和解决内存泄漏问题
Java面试题:深入探究Java内存模型与垃圾回收机制,解释JVM中堆内存和栈内存的主要区别,谈谈对Java垃圾回收机制的理解,Java中的内存泄漏及其产生原因,如何检测和解决内存泄漏问题
63 0
|
4月前
|
存储 算法 安全
Java面试题:Java内存模型及相关知识点深度解析,Java虚拟机的内存结构及各部分作用,详解Java的垃圾回收机制,谈谈你对Java内存溢出(OutOfMemoryError)的理解?
Java面试题:Java内存模型及相关知识点深度解析,Java虚拟机的内存结构及各部分作用,详解Java的垃圾回收机制,谈谈你对Java内存溢出(OutOfMemoryError)的理解?
69 0
|
2月前
|
存储 算法 Java
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
本文介绍了 JVM 的内存区域划分、类加载过程及垃圾回收机制。内存区域包括程序计数器、堆、栈和元数据区,每个区域存储不同类型的数据。类加载过程涉及加载、验证、准备、解析和初始化五个步骤。垃圾回收机制主要在堆内存进行,通过可达性分析识别垃圾对象,并采用标记-清除、复制和标记-整理等算法进行回收。此外,还介绍了 CMS 和 G1 等垃圾回收器的特点。
109 0
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
|
1月前
|
存储 Java PHP
【JVM】垃圾回收机制(GC)之引用计数和可达性分析
【JVM】垃圾回收机制(GC)之引用计数和可达性分析
52 0
|
4月前
|
Java
Jinfo 查看 jvm 配置及使用 Jstat 查看堆内存使用与垃圾回收
Jinfo 查看 jvm 配置及使用 Jstat 查看堆内存使用与垃圾回收
130 5
|
4月前
|
存储 算法 Java
JVM 垃圾回收算法与垃圾回收器
JVM 垃圾回收算法与垃圾回收器
45 3
|
4月前
|
监控 Java 运维
开发与运维收集问题之jstat命令查看JVM垃圾回收情况如何解决
开发与运维收集问题之jstat命令查看JVM垃圾回收情况如何解决
44 1