个人博客
http://www.lixiang.red/tech/java/2018/02/07/first-oom-java.html
欢迎点击,更多好技术好文在等着您!

OOM解释

oom全称是 out of memory,就是堆内存溢出。堆是JAVA虚拟机所管理的内存中最大的一块,也是所有线程共享的内存区域。

思路

  1. 既然是堆内存溢出,那就要往堆里面不断的塞东西。
  2. 给JAVA命令加上参数,把堆内存给限制下,这样能快速看到效果
  3. 通过jvisualvm看内存空间的变化

代码展示

我们将jvm参数做了如下设置

-Xms10m -Xmx10m

如下图通过man java 可以看到

-Xms: 初始化的堆大小。

-Xmx: 堆的最大内存。在本程序中将两者都初始化为10m

我的第一个OOM程序
man java
List<Object> oomObjects = new ArrayList<>();
while (true){
       oomObjects.add(new Object());
}

运行效果

我的第一个OOM程序
OOM

结果分析

代码非常简单,我们初始化了一个List , 然后死循环向里面添加数据。然后就可以看到控制台在报OOM的错误。

我们用jvisualvm 看一看堆内存的情况。为了有时间打开visualvm , 加了一行线程休眠的代码Thread.sleep(100000)主线程休眠10s。通过下图可以看到在休眠10s 之后,堆内存瞬间就满了,程序也随之停止。

我的第一个OOM程序
jvm-heap

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

我的第一个OOM程序
image

相关文章: