Memory Analyzer排查内存溢出

一、jmap 的使用

首先,需要使用 jmap 工具生成 dump 文件。

jmap是java自带的工具

1. 查看整个JVM内存状态 

jmap -heap [pid]

pid 为 java 进程号,可使用jps 或者 linux 命令行查看,

 

通过 ps -ef | grep java  得到如上线程将某线程终止时用 

kill -9 XXXXX     XXXXX为上述查出的序号  如: 19979线程终止为: kill -9 4834 

2. 查看JVM堆中对象详细占用情况
jmap -histo [pid]


3. 导出整个JVM 中内存信息,可以利用其它工具打开dump文件分析,例如jdk自带的visualvm工具

jmap -dump:file=文件名.dump [pid]

 

二、使用 Memory Analyzer 分析 dump 文件

生成Hrof 文件

生成heap文件

把studio生成的hrof文件导出使用hprof-conv.exe转换 ,注意这里不转换Memory Analyzer无法打开
\sdk\platform-tools 路径下面找到 hprof-conv.exe

转换hprof

转换后的文件我取名memory3333
使用Memory Analyzer打开转换后的文件

找到下载的Memory Analyzer

MemoryAnalyze
*
打开转换后的hrof文件

在这里插入图片描述

打开后

在这里插入图片描述

开始排查

点击histogram ,在Class Name这一栏输入你要过滤的类名,回车

histogram

搜索类名的结果 ,发现这个类有13个对象 ,正常情况找个类只有一个对象,所以这个类泄漏了

在这里插入图片描述

继续查找是谁使用了这个类 ,一直持有这个类的对象,导致无法释放
第一步: 排除需引用

在这里插入图片描述

第二步:找到被谁持有

在这里插入图片描述

结果

在这里插入图片描述

找到泄漏原因

在这里插入图片描述

在这里插入图片描述


结果,发现是CallBackManager类中的sCallBack持有了MemoryLeakActivity的引用
既然找到了原因 ,自己就去查看代码吧


根据包名查看

打开histogram ,根据图片步骤选择 Group by package

在这里插入图片描述

找到自己app包名 ,根据业务逻辑排查 ,大多数情况下一个只有一个实例 ,如果有多的怀疑是不是泄漏

在这里插入图片描述

在这里插入图片描述

使用查看Memory Analyzer线程

在这里插入图片描述

 

使用Memory Analyzer数据库方式搜索类名,查看改类是否存在异常

在这里插入图片描述

 

dominator_tree查看内存占比 ,排斥占用内存多的原因 ,把占用内存多的释放掉

在这里插入图片描述

 

其它

在这里插入图片描述

 

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值