07-12 内存检测工具(一) Leakcanary 基础集成使用

纵使我们技术不是很全面但也阻挡不了我们想做好APP的心.

内存泄漏我们都只要要考虑,但是那么多我们总不能做到面面俱到,什么情况都可以考虑全面,还好前人种树后人乘凉,今天就简单介绍下Leakcancry 的继承.

准备工作

1.Gradle 引入

   debugImplementation 'com.squareup.leakcanary:leakcanary-android:1.5.4'
   releaseImplementation 'com.squareup.leakcanary:leakcanary-android-no-op:1.5.4'

2-1使用 Java 写法

public class IApplication extends Application {

    public static RefWatcher getRefWatcher(Context context) {
        IApplication application = (IApplication) context.getApplicationContext();
        return application.mRefWatcher;
    }

    //用于自动监控调用Activity.onDestroy() 之后泄露的 activity。
    RefWatcher mRefWatcher = null;

    @Override
    public void onCreate() {
        super.onCreate();
        
        //LeakCanary.install() 会返回一个预定义的 RefWatcher,同时也会启用一个 ActivityRefWatcher
        mRefWatcher = LeakCanary.isInAnalyzerProcess(this) ? RefWatcher.DISABLED : LeakCanary.install(this);

    }

Ps: 在BaseActivity 的onDestory 方法中 调用
    IApplication.getRefWatcher(this).watch(this);

2-2 使用 Kotlin (正在练习,求师傅~~ )

class KApp : Application(){

  private var refWatcher : RefWatcher ? = null

  companion object {

      private val TAG = "MyApplication"

      var context: Context by Delegates.notNull()
          private set

      fun getRefWatcher(context: Context): RefWatcher? {
          val kApp = context.applicationContext as KApp
          return kApp.refWatcher
      }

  }

  override fun onCreate() {
      super.onCreate()

      context = applicationContext
      refWatcher = setupLeakCanary()
  }

  /**
   *  初始化内存泄漏检测
   */
  private fun setupLeakCanary(): RefWatcher {
      return if (LeakCanary.isInAnalyzerProcess(this)) {
          RefWatcher.DISABLED
      } else LeakCanary.install(this)
  }

}
PS:在BaseActivity 的onDestory 方法中 调用
   KApp.getRefWatcher(this)?.watch(this)

工作机制 (摘自: rongbinjava的博客)

  1. RefWatcher.watch() 创建一个 KeyedWeakReference 到要被监控的对象。

  2. 然后在后台线程检查引用是否被清除,如果没有,调用GC。

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

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

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

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

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

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 今天是高考的日子,给大家分享一篇文章,这篇文章触动了许许多多的人,在美国许多报纸杂志都刊登过,电视收音机转播过,大...
    金榕觉醒阅读 10,290评论 0 3
  • 敲下标题两个字,心里有股暖流在流动。也许从这两天的疲惫无力到现在状态的转变,只是因为中午自己找了个安静的地方,哭了...
    绽蕊向阳阅读 1,852评论 2 5
  • Spring Boot 1.3.0.BUILD-SNAPSHOT 需要Java7和Spring框架4.1.3或以上...
    Angeladaddy阅读 2,515评论 0 0