java内存溢出的定位和分析
生活随笔
收集整理的這篇文章主要介紹了
java内存溢出的定位和分析
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
內存溢出在實際的生產環境中經常會遇到,比如,不斷的將數據寫入到一個集合中,出現了死循環,讀取超大的文件等,都會造成內存溢出。
如果出現了內存溢出,首先我們需要定位到發生內存溢出的環節,并進行分析,是正常情況還是非正常情況,如果是正常的需求,就應該考慮加大內存的設置,如果不是正常的需求,那么就要對代碼進行修改,修復這個bug。
1.模擬內存溢出
public class TestJVMOutOfMemory {public static void main(String[] args) {List<Object> list = new ArrayList<>();for (int i = 0; i < 1000000; i++) {StringBuilder str = new StringBuilder();for (int j = 0; j < 1000; j++) {str.append(UUID.randomUUID().toString());}list.add(str.toString());}System.out.println("ok");} }設置啟動參數以更快的出現問題
-Xms8m -Xmx8m -XX:+HeapDumpOnOutOfMemoryError測試結果如下:
java.lang.OutOfMemoryError: Java heap space Dumping heap to java_pid1102.hprof ... Heap dump file created [7959370 bytes in 0.063 secs] Exception in thread "main" java.lang.OutOfMemoryError: Java heap spaceat java.util.Arrays.copyOfRange(Arrays.java:3664)at java.lang.String.<init>(String.java:207)at java.lang.StringBuilder.toString(StringBuilder.java:407)at com.yfy.demo01.TestJVMOutOfMemory.main(TestJVMOutOfMemory.java:21)2.在MAT中進行分析
?
可以看到,有93.88的內存由Object[]數組占有。這個地方是有可能出現內存溢出的。
點擊Details查看詳情:
?
可以看到集合中存儲了大量的uuid字符串。
總結
以上是生活随笔為你收集整理的java内存溢出的定位和分析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 内存分析工具MAT介绍
- 下一篇: 使用redis的zset实现排行榜