三种方式查看 JVM 垃圾收集器

一、引言

不同版本的 JVM默认使用的垃圾收集器是不同的,目前的新生代和老年代的垃圾收集器如下图所示,新生代和老年代之间的连线表示这些垃圾收集器可以进行搭配使用

垃圾收集器的名字和 JVM 里面的参数对照表如下,即在 JVM里面并不是存储的垃圾收集器的名字,而是有一个其他的名字。它是有一个对应关系的,如下所示:

|-------------------|----------------------------------|
| 垃圾收集器类型 | JVM 参数名称 |
| Serial | def new generation |
| ParNew | par new generation |
| Parallel Scavenge | PSYoungGen |
| Parallel Old | ParOldGen |
| CMS | concurrent mark-sweep generation |
| Serial Old(MSC) | tenured generation |
| G1 | garbage-first heap |
| ZGC | |

二、方法

2.1 PrintCommandLineFlags

这种方式仅适用于 windows 平台,直接在控制台输入下面的命令行,可以从展示信息中看到 当前机器 JVM 的垃圾回收器类型

XML 复制代码
java -XX:+PrintCommandLineFlags -version
bash 复制代码
# 输入命令:java -XX:+PrintCommandLineFlags -version
C:\Users\Administrator>java -XX:+PrintCommandLineFlags -version
-XX:InitialHeapSize=255140800 -XX:MaxHeapSize=4082252800 -XX:+PrintCommandLineFlags -XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:-UseLargePagesIndividualAllocation -XX:+UseParallelGC
java version "1.8.0_131"
Java(TM) SE Runtime Environment (build 1.8.0_131-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.131-b11, mixed mode)

2.2 通过 GC 日志和堆信息

默认情况下,GC 日志和 Heap 信息我们是看不到的,可以通过增加 VM 参数的方式启动。这样当 GC 发生时,我们就能看到关于垃圾回收器的相关信息了。

我们人为制造一个 full gc 的操作,然后添加 vm 参数,观察输出日志的变化,如下所示:

java 复制代码
public class Test {
	
	public static void main(String[] args) {
		List<Object> list = new LinkedList<>();
		while(true){
			list.add(new byte[1024]);
		}
	}
}
java 复制代码
-verbose:gc -XX:+PrintGCDetails

2.3 通过 jmap -heap vmid

相关推荐
2401_8323655210 小时前
JavaScript中rest参数(...args)取代arguments的优势
jvm·数据库·python
2301_7796224110 小时前
Go语言怎么用信号量控制并发_Go语言semaphore信号量教程【入门】
jvm·数据库·python
2301_7662834410 小时前
c++如何将控制台输出保存到文件_cout重定向到txt【详解】
jvm·数据库·python
zh15702315 小时前
如何编写动态SQL存储过程_使用sp_executesql执行灵活查询
jvm·数据库·python
2401_8242226915 小时前
SQL报表统计数据量巨大_分批统计策略
jvm·数据库·python
X566115 小时前
mysql如何处理连接数过多报错_调整max_connections参数
jvm·数据库·python
m0_6091604916 小时前
MongoDB中什么是Hashed Shard Key的哈希冲突_哈希函数的分布均匀性分析
jvm·数据库·python
2401_8330336218 小时前
C#怎么使用协变和逆变 C#泛型中的in和out关键字协变逆变是什么意思怎么用【语法】
jvm·数据库·python
m0_6245785918 小时前
JavaScript 中高精度小数(20位以上)的正确处理方法
jvm·数据库·python
m0_7403524218 小时前
如何用 Symbol 作为对象属性键名防止第三方库属性覆盖
jvm·数据库·python