Android AndroidStudio MAT LeakCanary 内存分析之 DDMS+MAT

Android AndroidStudio MAT LeakCanary 内存分析之 初识内存泄漏
http://blog.csdn.net/qq_28195645/article/details/51733342

Android AndroidStudio MAT LeakCanary 内存分析之 AndroidStudio 内存泄漏分析 Memory Monitor
http://blog.csdn.net/qq_28195645/article/details/51734506

Android AndroidStudio MAT LeakCanary 内存分析之 LeakCanary
http://blog.csdn.net/qq_28195645/article/details/51734987

Android AndroidStudio MAT LeakCanary 内存分析之 DDMS+MAT
http://blog.csdn.net/qq_28195645/article/details/51735522

下载MAT打开hprof文件

http://www.eclipse.org/mat/downloads.php

我们可以直接通过Monitor来获取hprof文件、

详见 Android AndroidStudio MAT LeakCanary 内存分析之 AndroidStudio 内存泄漏分析 Memory Monitor

Android AndroidStudio MAT LeakCanary 内存分析之 DDMS+MAT_第1张图片

我们也可以通过DDMS来获取到、

怪麻烦、还是通过上面的方法吧
Android AndroidStudio MAT LeakCanary 内存分析之 DDMS+MAT_第2张图片

按照以上三步 导出 然后通过MAT打开、会发现以下问题

Unknown HPROF Version (JAVA PROFILE 1.0.3)
Android AndroidStudio MAT LeakCanary 内存分析之 DDMS+MAT_第3张图片
原因是: android的虚拟机导出的内存文件hprof文件格式与标准的 java hprof文件格式标准不一样,根本原因两者的虚拟机不一致导致的。
只需要使用SDK中自带的转换工具转换就可以了
hprof-conv 源文件 目标文件

通过MAT打开并进行分析

Android AndroidStudio MAT LeakCanary 内存分析之 DDMS+MAT_第4张图片

在OQL(Object Query Language)窗口下输入的查询命令可以获得所有在内存中的Activities

在窗口输入

select * from instanceof android.app.Activity

按Ctrl + F5或者!按钮

Android AndroidStudio MAT LeakCanary 内存分析之 DDMS+MAT_第5张图片

Android AndroidStudio MAT LeakCanary 内存分析之 DDMS+MAT_第6张图片

在打开的新窗口中,你可以发现,你的Activity是被this 0this 0又被callback所引用,接着它又被Message中一串的next所引用,最后到主线程才结束。

任何情况下你在class中创建非静态内部类,内部类会(自动)拥有对当前类的一个强引用。

一旦你把Runnable或者Message发送到Handler中,它就会被放入LooperThread的消息队列,并且被保持引用,直到Message被处理。发送postDelayed这样的消息,你输入延迟多少秒,它就会泄露至少多少秒。而发送没有延迟的消息的话,当队列中的消息过多时,也会照成一个临时的泄露。

你可能感兴趣的:(Android进阶)