博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java.lang.OutOfMemoryError: Java heap space 内存溢出问题排查
阅读量:4215 次
发布时间:2019-05-26

本文共 501 字,大约阅读时间需要 1 分钟。

最近一直排查系统中的内存溢出问题。

不管是用jmap指令还是用比较直观的jvisualvm工具。都可以看到堆内存中各个对象的数量以及占用的内存大小。

一般只要找到有大量的自定义对象一直无法释放,那么距离定位到问题就不远了。

来看一个例子吧:

就像图里看到的这样 一般都是这些对象数量巨大内存大部分也都是他们占用的。

今天明确了一个问题,这里统计的String对象指所有的String对象,包含在其他类中的属性。

比如我们自定义一个类 xxx 有10个String类型的属性,如果有10万个xxx对象,那么堆里就会多100万个String对象。(所有属性都必须是有值的而且是一个新的对象)。

而当我们看到自定义对象只占用内存的百分之几的时候,要知道对象如果属性很多的话,算是我们对象引用的所有对象。占用的总内存可能是非常大的。

如果某个线程执行时间过长,那么就很危险了。占用的内存无法释放。就容易造成内存的溢出。

如果自定义对象超过10万,就有内存溢出的危险了。

内存溢出的问题,首先看对象数会不会太多,如果太多可能 直接在创建过程中就溢出了。

其次,看线程的处理时间,如果能很快结束,内存就会很快释放。

你可能感兴趣的文章
【XCode 4.6】常用快捷键 特别是格式化代码ctrl+i
查看>>
【iOS游戏开发】icon那点事 之 图标设计(三)
查看>>
【IOS游戏开发】之测试发布(Distribution)
查看>>
【IOS游戏开发】之IPA破解原理
查看>>
【一天一道LeetCode】#45. Jump Game II
查看>>
【一天一道LeetCode】#56. Merge Intervals
查看>>
【一天一道LeetCode】#58. Length of Last Word
查看>>
【一天一道LeetCode】#59. Spiral Matrix II
查看>>
【一天一道LeetCode】#30. Substring with Concatenation of All Words
查看>>
【一天一道LeetCode】#60. Permutation Sequence.
查看>>
【unix网络编程第三版】阅读笔记(二):套接字编程简介
查看>>
【一天一道LeetCode】#116. Populating Next Right Pointers in Each Node
查看>>
【一天一道LeetCode】#118. Pascal's Triangle
查看>>
JAVA实现文件树
查看>>
ebay api - GetUserDisputes 函数
查看>>
ebay api GetMyMessages 函数
查看>>
手动12 - 安装php加速器 Zend OPcache
查看>>
set theme -yii2
查看>>
yii2 - controller
查看>>
yii2 - 增加actions
查看>>