java内存溢出的定位和分析
生活随笔
收集整理的這篇文章主要介紹了
java内存溢出的定位和分析
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
內(nèi)存溢出在實際的生產(chǎn)環(huán)境中經(jīng)常會遇到,比如,不斷的將數(shù)據(jù)寫入到一個集合中,出現(xiàn)了死循環(huán),讀取超大的文件等,都會造成內(nèi)存溢出。
如果出現(xiàn)了內(nèi)存溢出,首先我們需要定位到發(fā)生內(nèi)存溢出的環(huán)節(jié),并進行分析,是正常情況還是非正常情況,如果是正常的需求,就應(yīng)該考慮加大內(nèi)存的設(shè)置,如果不是正常的需求,那么就要對代碼進行修改,修復這個bug。
1.模擬內(nèi)存溢出
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");} }設(shè)置啟動參數(shù)以更快的出現(xiàn)問題
-Xms8m -Xmx8m -XX:+HeapDumpOnOutOfMemoryError測試結(jié)果如下:
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的內(nèi)存由Object[]數(shù)組占有。這個地方是有可能出現(xiàn)內(nèi)存溢出的。
點擊Details查看詳情:
?
可以看到集合中存儲了大量的uuid字符串。
總結(jié)
以上是生活随笔為你收集整理的java内存溢出的定位和分析的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 内存分析工具MAT介绍
- 下一篇: 使用redis的zset实现排行榜