深入理解JAVA虚拟机---GC日志详解

本文深入探讨JAVA虚拟机的垃圾回收日志,详细解释了GC日志中的各项指标,如年轻代、年老代和永久代的内存使用情况,以及不同类型的垃圾回收过程。通过一个HeapOutOfMemoryExample的示例,展示了GC日志如何记录内存分配和回收的过程,帮助开发者理解和优化JVM内存设置。

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

1.编写JAVA代码

import java.util.ArrayList;
import java.util.List;
/**
 * -verbose:gc -Xms30M -Xmx30M -Xmn10M -XX:PermSize=200M -XX:MaxPermSize=200M -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:SurvivorRatio=8
 * @author Administrator
 *parallel Scanvenge
 */
public class HeapOutOfMemoryExample {

	public static void main(String[] args) {
		List<Object> list = new ArrayList<Object>();
		while(true) {
			list.add(new Object());
		}
		
	}

}
2.设置JVM参数

-verbose:gc -Xms30M -Xmx30M -Xmn10M -XX:PermSize=200M -XX:MaxPermSize=200M -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:SurvivorRatio=8

JVM参数说明

Xms=30M  //最小堆内存

Xmx=30M  //最大堆内存

Xmn=10M  //年轻代所占内存

PermSize=200M //永久代所占最小内存

MaxPermSize=200M  //永久代所占最大内存

SurvivorRatio=8   //年轻代中Eden区和Survivor区的比值

PrintGCDetails    //打印出垃圾回收日志

PrintGCDateStamps //打印出垃圾回收的时间

3.执行类HeapOutOfMemoryExample

打印出GC日志

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值