码迷,mamicode.com
首页 > 其他好文 > 详细

Jprofile使用随笔_2_内存泄漏

时间:2019-10-21 20:37:03      阅读:103      评论:0      收藏:0      [点我收藏+]

标签:info   模拟   order   查看   分配   ted   遍历   image   win   

上一篇写了安装以及windows监听服务器。这一篇写如何查看jvm有无内存泄漏。

内存泄漏:是指程序中己动态分配的堆内存由于某种原因程序未释放或无法释放,造成系统内存的浪费,导致程序运行速度减慢甚至系统崩溃等严重后果。

 

使用一个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...太难了,老老实实记笔记

Jprofile使用随笔_2_内存泄漏

标签:info   模拟   order   查看   分配   ted   遍历   image   win   

原文地址:https://www.cnblogs.com/jinziguang/p/11715749.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!