1.Android 导出hprof到mat

mat工具:链接:https://pan.baidu.com/s/1lCi1ZKomRGjpT_D7kiZepg
提取码:sdvk
也可以https://www.eclipse.org/mat/ 通过官网下载

1.1.Android studio生成hprof文件

点击AS Profiler 这一项

MAT分析javacore mat分析hprof文件_MAT分析javacore


MAT分析javacore mat分析hprof文件_ide_02


点击下载按钮这一项,

MAT分析javacore mat分析hprof文件_android studio_03


堆转储界面点击红框处按钮

此时就生成hprof文件了

ps:上面三个标记按钮的作用:

1、内存回收;

2、堆转储,将此时堆内存中的对象记录导出到hprof文件中;

3、一段时间内堆内存中的分配记录,比如:点击开始,操作app,操作结束后,再次点击结束,这时就会生成一个记录了这段时间内堆中生成的对象。

此时生成的hprof是无法直接导入mat工具的,此时就需要使用android sdk下的hprof-conv.exe将导出的hprof转换一下

MAT分析javacore mat分析hprof文件_android_04


执行 hprof-conv D:\start.hprof(文件名) D:\startconv.hprof(转换后的文件名)

MAT分析javacore mat分析hprof文件_ide_05


此时 MAT就可以打开这个hprof文件了

使用MAT分析hprof文件

使用MAT导入hprof文件

MAT分析javacore mat分析hprof文件_android_06


1、Histogram是针对对象的数量,可以这么理解,一个类可以创建多个对象,这里查看的就是一个类总共创建了多少个对象;2、Dominator Tree是针对的对象引用关系,以及该类所有实例对象所占用内存的百分比;

点击Histogram后

MAT分析javacore mat分析hprof文件_android_07


比较两个hprof文件,通过两个文件对比可以发现内存增长在何处,

MAT分析javacore mat分析hprof文件_Android_08


选择Add to Compare Basket

MAT分析javacore mat分析hprof文件_Android_09


这样就可以看出内存增长在那个类,如果还想继续看详细的增长可以

MAT分析javacore mat分析hprof文件_Android_10


通过对比可以发现byte[]增长主要在ad-pool的线程数量的增长

MAT分析javacore mat分析hprof文件_android studio_11


MAT分析javacore mat分析hprof文件_MAT分析javacore_12

通过上述步骤,就可以找到内存增长发生在何处。

结合leakcanary, Android profiler,结合MAT基本就可以解决内存泄露问题了