java内存泄露检测_Android和Java内存泄漏检测 – leakcanary

LeakCanary是Android 和 Java 内存泄露检测工具。

2IFz6n.png

使用方法

在 build.gradle 中加入引用,不同的编译使用不同的引用:

dependencies {

? debugCompile 'com.squareup.leakcanary:leakcanary-android:1.3'

? releaseCompile 'com.squareup.leakcanary:leakcanary-android-no-op:1.3'

}

在 Application 中:

public class ExampleApplication extends Application {

?@Override public void onCreate() {

? ?super.onCreate();

? ?LeakCanary.install(this);

?}

}

这样,就万事俱备了! 在 debug build 中,如果检测到某个 activity 有内存泄露,LeakCanary 就是自动地显示一个通知。

工作机制

1RefWatcher.watch() 创建一个 KeyedWeakReference 到要被监控的对象,然后在后台线程检查引用是否被清除,如果没有,调用GC。

2如果引用还是未被清除,把 heap 内存 dump 到 APP 对应的文件系统中的一个 .hprof 文件中。

3在另外一个进程中的 HeapAnalyzerService 有一个 HeapAnalyzer 使用HAHA 解析这个文件。

4得益于唯一的 reference key, HeapAnalyzer 找到 KeyedWeakReference,定位内存泄露。

5HeapAnalyzer 计算 到 GC roots 的最短强引用路径,并确定是否是泄露。如果是的话,建立导致泄露的引用链。

6引用链传递到 APP 进程中的 DisplayLeakService, 并以通知的形式展示出来。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值