Jprofile使用随笔_2_内存泄漏
上一篇写了安装以及windows监听服务器。这一篇写如何查看jvm有无内存泄漏。
内存泄漏:是指程序中己动态分配的堆内存由于某种原因程序未释放或无法释放,造成系统内存的浪费,导致程序运行速度减慢甚至系统崩溃等严重后果。
大致来说是以下三个过程:
a.揣测,先在Memory Views里点击可能出现泄漏的类,然后add到class tracker
b.跟踪,查看class tracker中曲线变化,增长过快或增长却不释放,则出现了内存泄漏
c.追溯,定位类后就看是谁引用这个类的内存却没有释放,在heap walker中找到类,右键查看他的引用references,针对可能的类进行浏览,确定根源在哪里
使用一个Jprofile自带的例子:Animated Bezier Curve Demo。
如图:这个自带的例子,是一个二维图形的demo,这个demo有三个复选框,分别是内存泄漏、模拟阻塞、模拟长时间运行。本文分析内存泄漏,所以勾选“Leak Memory”。
1.先进入【Live Memory】-【Recorded Objects】,点击顶部菜单栏中的【Recorder Memory】,开始记录;此时点击【Mark Current】,以便于之后的与变化做对比。
2.多次手动GC,查看哪个类的增量不减少,一直增加,如图:
3.以java.lang.long为例,右键-在堆遍历中查看该类是哪个地方导致了内存泄漏,查看References-Incoming references
4.继上一步,右键点击查看:
内存泄漏发现到根源,至此结束。
jvm...太难了,老老实实记笔记