51.LeakCanary分析

使用

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

public class MyApplication extends Application {
      @Override
      public void onCreate() {
             super.onCreate();
             LeakCanary.install(this)
      }
}

源码

1.LeakCanary是怎么做到install之后自动监测Activity的?

调用install后,会注册一个Activity生命周期的回调监听,registerActivityLifecycleCallbacks,来绑定Activity生命周期,在Activity执行onDestroy时,调用watch方法开始检测当前页面是否存在内存泄漏,并分析结果(如果想要在非Activity如Fragment检测是否存在内存泄漏,需要手动添加,调用watch方法)

2.如何判定Activity是否发生了内存泄漏

KeyedWeakReference与ReferenceQueue联合使用,将onDestroy的Activity对象包裹成一个弱引用对象(KeyedWeakReference),开启异步线程,在弱引用关联的对象被回收后,会将引用添加到ReferenceQueue;清空后,可以根据是否继续含有该引用来判定是否被回收;判定回收, 手动GC, 再次判定回收,采用双重判定来确保当前引用是否被回收的状态正确性;如果两次都未回收,则确定为泄漏对象。

3.内存泄漏轨迹是如何生成的

采用eclipse.Mat来分析泄漏详细,从GCRoot开始逐步生成引用轨迹。

4.内存分析是在单独的进程执行的吗,为什么?

内存分析模块是在独立进程中执行的,这么设计是为了保证内存分析过程不会对App进程造成消极的影响

5.检测是否发生泄漏是在主线程还是子线程

开启了一个子线程检测的

5.Leak Canary核心类及其作用

1.DisplayLeakActivity
内存泄漏的查看页面
2.HeapAnalyzerService
内存堆分析服务, 为了保证App进程不会因此受影响变慢&内存溢出,运行于独立的进程
3.HeapAnalyzer
分析由RefWatcher生成的堆转储信息, 验证内存泄漏是否真实存在
4.HeapDump
堆转储信息类,存储堆转储的相关信息
5.ServiceHeapDumpListener
一个监听,包含了开启分析的方法
6.RefWatcher
核心类, 翻译自官方: 检测不可达引用(可能地),当发现不可达引用时,它会触发
7.HeapDumper
(堆信息转储)
8.ActivityRefWatcher
Activity引用检测, 包含了Activity生命周期的监听执行与停止

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章