一、場景:假如是線上環境,沒有IDE,我們在本地用IDEA模擬測試。
二、代碼:
package com.play.english.jdk;
import java.util.ArrayList;
import java.util.List;
/**
* @author chaiqx on 2019/12/24
*/
public class Oom {
private List<Oom> list = new ArrayList<>(100000);
public List<Oom> getList() {
return list;
}
public void setList(List<Oom> list) {
this.list = list;
}
public static void main(String[] args){
List<Oom> list = new ArrayList<>();
while(true){
list.add(new Oom());
}
}
}
三、設置JVM運行參數
-XX:+HeapDumpOnOutOfMemoryError
-XX:HeapDumpPath=/Users/chaiqunxing/Desktop/java_error_in_idea.hprof
這參數的意義,可以自行搜索理解。
四:運行程序,果不其然,heap溢出,目前是在IDEA上直接能看到OOM,但是線上的話也許只會有OOM報警。
五、分析dump出來的hprof文件,利用jhat
jhat java_error_in_idea.hprof
打開瀏覽器,端口號爲7000.主要關注下面這兩個。點進去查看~
六、總結,大概就能找到問題所在的類,進而閱讀代碼稍微分析就能找出原因。