内存溢出的排查和定位

内存溢出是一个面试时常问的问题,今天写个小栗子总结一下。

1.内存溢出的例子。

package org.example;
import java.util.ArrayList;
import java.util.List;


public class test2 {
    public static void main(String[] args) {
        List<jvmTest> list = new ArrayList<>();
        while (true) {
            list.add(new jvmTest()); // 不断创建对象,导致内存溢出
        }
    }
}

如上所示,jvmTest是我自定义的一个类,不断创建对象,最终会导致内存溢出。

2.导出dump文件。

在运行这个main方法的时候加几个参数,如图。

 具体参数为:

-Xms20m -Xmx20m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:/dump

这几个参数的意义为,设置JVM堆内存的初始大小和最大值,方便演示,设置内存溢出以后输出dump文件,指定生成的文件路径。

运行以后如图所示:

 

3.查看dump文件。

打开jdk目录bin目录下面的jvisualvm.exe,点击文件-》装入,打开生成的hprof文件。

 

 

 

 

 如图所示,可以直观的看到是jvmTest这个类占据了大部分内存。导致了内存溢出。

 

posted @ 2024-08-08 15:25  兰溪三日桃花雨  阅读(22)  评论(0编辑  收藏  举报