内存泄露排查工具MAT的使用
在程序运行时加上+HeapDumpOnOutOfMemoryError在OOM时会导出堆信息到hprof文件。
本次测试用的代码如下
public class Test02 {
byte[] bytes = new byte[1*1024*1024];
public static void main(String[] args) {
List<Test02> list = new ArrayList<Test02>();
try {
for (int i = 0; i <= 40; i++) {
list.add(new Test02());
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
为了快速出现OOM,此处我们加初始堆大小设为1M,最大堆大小设为8M。
在启动参数中设置如下信息
-Xms1m -Xmx8m -XX:+HeapDumpOnOutOfMemoryError
运行此代码。结果如下
可以看出,生成了一个名为java_pid8100的hprof文件。
去代码所在目录可以看到此文件。
使用MAT打开此文件。
MAT会帮助我们分析出内存泄露发生的位置,以及此时详细的内存信息。