示例
package com.rumenz;
import java.util.ArrayList;
import java.util.List;
public class OutOfMemory {
public static void main(String[] args) {
List<UserTest> res=new ArrayList<>();
while (true){
res.add(new UserTest());
}
}
}
class UserTest{
}
VM 添加参数
-Xms20m -Xmx20m
输出:
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at com.rumenz.OutOfMemory.main(OutOfMemory.java:11)
解释:
通过VM参数控制JVM的堆内存大小只有20m,程序不停的创建对象,而对象又是在堆上分配内存,一直不停的向List中添加对象,没有垃圾回收,导致堆内存溢出(OutOfMemoryError).
Mat工具分析堆
1.下载Mat分析软件: https://www.eclipse.org/mat/d...
2.VM参数加上: -XX:+HeapDumpOnOutOfMemoryError 开启堆内存溢出导出堆内存到文件,默认在项目的根目录下.如果需要指定其它路径用 -XX:HeapDumpPath=/tmp ,会生成一个名字类似的 java_pid28790.hprof 文件.
3.使用Mat打开hprof文件