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会帮助我们分析出内存泄露发生的位置,以及此时详细的内存信息。