个人博客
http://www.lixiang.red/tech/java/2018/02/07/first-oom-java.html
欢迎点击,更多好技术好文在等着您!
OOM解释
oom全称是 out of memory,就是堆内存溢出。堆是JAVA虚拟机所管理的内存中最大的一块,也是所有线程共享的内存区域。
思路
- 既然是堆内存溢出,那就要往堆里面不断的塞东西。
- 给JAVA命令加上参数,把堆内存给限制下,这样能快速看到效果
- 通过jvisualvm看内存空间的变化
代码展示
我们将jvm参数做了如下设置
-Xms10m -Xmx10m
如下图通过man java
可以看到
-Xms: 初始化的堆大小。
-Xmx: 堆的最大内存。在本程序中将两者都初始化为10m

man java
List<Object> oomObjects = new ArrayList<>();
while (true){
oomObjects.add(new Object());
}
运行效果

OOM
结果分析
代码非常简单,我们初始化了一个List , 然后死循环向里面添加数据。然后就可以看到控制台在报OOM的错误。
我们用jvisualvm 看一看堆内存的情况。为了有时间打开visualvm , 加了一行线程休眠的代码Thread.sleep(100000)
主线程休眠10s。通过下图可以看到在休眠10s 之后,堆内存瞬间就满了,程序也随之停止。

jvm-heap
注:欢迎扫描下方二维码关注我哦

image