一使用步骤
添加依赖
// 内存泄漏检测 debugCompile 'com.squareup.leakcanary:leakcanary-android:1.5.4' releaseCompile 'com.squareup.leakcanary:leakcanary-android-no-op:1.5.4'
- 在application中注册.后面有代码
运行项目后会出现图标如下,如果有泄漏会以列表的形式进行展现;
二注意事项
由于我们这个项目是有多个moudle,一开始是LeakCanary是配置在commonlib项目下的,项目的application也是在commonlib下applicationLib里写入的,这样发现不行,后来将项目环境切成每个moudle单独运行,这时我所有配置项都在marketbundle这个里面配置了,这时发现是可以进行内存检测了;
# 是否是module环境file:// IS_MODULE=false
- 总结教训:一开始由于配置全部是在commomlib下面的,我app下面的application去继承commomlib的applicationlib,applicationlib写了Leakcanary的注册这时发现是不行的,安装app后并没有黄色的Leaks图标出现,而我自己试验自己的appDemo是完全可以的,这个时候其实我就应该意识到这个内存泄漏注册应该是在主app的moudle里面进行,而我走了很多的弯路,最后一步一步排除过来才完成了配置,总而言之注意2点
- 在gradle里面配置的依赖和application必须是在同一个moudle下,并一定是主moudle;(多个modle情况下,一个的话就不存在这种情况)
- 必须在当前application里面实现注册代码
public class HostApplication extends ApplicationLib {
//
private String TAG = HostApplication.class.getSimpleName();
public RefWatcher refWatcher;
@Override
public void onCreate() { //必须在这个方法里面进行创建和注册,不要在lib里面写一个abstract方法这里面继承,不能这样
Log.i(TAG, "onCreate");
super.onCreate();
refWatcher = setupLeakCanary();
}
private RefWatcher setupLeakCanary() {
JLog.i(TAG, "LeakCanary setupLeakCanary");
//如果当前的进程是用来给LeakCanary 进行堆分析的则return,否则会执行LeakCanary的install方法。这样我们就可以使用LeakCanary了,如果检测到某个Activity 有内存泄露,LeakCanary 就会给出提示。
if (LeakCanary.isInAnalyzerProcess(this)) {
JLog.i(TAG, "LeakCanary isInAnalyzerProcess");
return RefWatcher.DISABLED;
}
return LeakCanary.install(this);
}
public static RefWatcher getRefWatcher(Context context) {
HostApplication leakApplication = (HostApplication) context.getApplicationContext();
return leakApplication.refWatcher;
}
}