文Java文件导出内存溢出_JVM参数之-XX:+HeapDumpOnOutOfMemoryError(导出内存溢出的堆信息(hprof文件))...

本文介绍了如何通过Java程序模拟触发`HeapDumpOnOutOfMemoryError`错误,并设置JVM参数来导出堆信息(hprof文件)进行分析。示例代码展示了如何创建内存溢出,然后通过`jmap`工具或直接设置`XX:HeapDumpPath`导出堆转储文件。使用内存分析工具MAT对文件进行分析,以识别可能的内存泄漏问题。
摘要由CSDN通过智能技术生成

当出现HeapDumpOnOutOfMemoryError错误时,我们需要分析原因,下面的程序就是模拟这个错误并导出dump文件,好让你分析

GcTest.java

packagegc;public classGcTest {private static final int _1MB= 1024 * 1024; //约1m

public static voidmain(String[] args) {//总共约8m多,堆大小设置不超过8388608B即8.388608m就会内存溢出,但是需要整数,小于8M就会重现这个错误

byte[] a1, a2, a3, a4;

a1= new byte[2 *_1MB];

a2= new byte[2 *_1MB];

a3= new byte[2 *_1MB];

a4= new byte[2 *_1MB];

}

}

这个文件在桌面上,所以执行编译:

PwEiUqDBSVBgpLIwUFkQKCyIE+UgpAADwAH+a1i9O4xOt8I6QLAvmWVJqKpwsmyAfKQUAAJ7hT9P5xWl8o9N9IsTLQ7iWlIoQFExv+UgpAADwlP8HJ8xEqFfjiDoAAAAASUVORK5CYII=

执行 GcTest.bat:

set CLASSPATH=C:\Users\andy\Desktop\gc;

java-Xms10M -Xmx10M -Xmn2M -XX:SurvivorRatio=8 -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\study\log_hprof\gc.hprof -XX:+PrintGCDetails -Xloggc:D:\study\log_gc\gc.log gc.GcTest

pause

结果如下:

d913c5e1a6c617951aee893a6680bdae.png

gc.hprof文件用内存分析工具分析如mat打开 分析

User.java

961ddebeb323a10fe0623af514929fc1.png

48304ba5e6f9fe08f3fa1abda7d326ab.png

package gc;

import java.util.ArrayList;

import java.util.List;

/**

* @Package gc

* @ClassName: User

* @Description: TODO(这里用一句话描述这个类的作用)

* @author andy

* @date 2013-6-9 下午4:46:13

*/

public class User {

private String id;

private String name;

public String getId() {

return id;

}

public void setId(String id) {

this.id = id;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public User(String id, String name) {

super();

this.id = id;

this.name = name;

}

public static void main(String[] args) {

List list = new ArrayList();

for (int i = 1; i < 10000; i++) {

User o = new User(i + "", System.currentTimeMillis() + "");

list.add(o);

o = null;

}

System.out.println("end");

try {

Thread.sleep(100000000l);

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}

48304ba5e6f9fe08f3fa1abda7d326ab.png

运行user任务管理器查看到的pid号:

c1AKRPLxTu6SC36v3PkFO7ApKFmPs2sAAAAASUVORK5CYII=

基于jmap导出的堆信息:

Sf1bsBwM714JQAAAABJRU5ErkJggg==

用装了mat插件的eclipse打开firstHeap.bin文件

选择Leak Suspects Reports模式,finish

OVvS3+d7BYhhBBC+Qi7RQghhAoXdosQQggVLuwWIYQQKlzYLUIIIVS4sFuEEEKocGG3CCGEUOHCbhFCCKHChd0ihBBChQu7RQghhAoXdosQQggVrv8PhgfnIwdnoVMAAAAASUVORK5CYII=

点击details

H8EDGUAUzl6+wAAAABJRU5ErkJggg==

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值