Android性能优化之LeakCanary使用详解

前言

这段时间要开始重构公司之前的安卓项目,在一年多安卓开发中,很多技术都是停留在"听过"的阶段,借这次重构机会,准备"重新做人",将技术真正用到项目中。Android开发中,性能优化不管是在项目里还是在面试过程中出现频率都是较高的,内存泄漏是项目中常出现的问题,本篇将介绍LeakCanary


使用LeakCanary

1.build.gradle配置

  
  /*内存泄漏检测 leak-canary*/
    debugImplementation 'com.squareup.leakcanary:leakcanary-android:1.5.4'
    releaseImplementation 'com.squareup.leakcanary:leakcanary-android-no-op:1.5.4'

2.Application配置


public class MyApplication : Application() {

    /**
     *  @funtion:onCreate()
     *  @leakcanary 内存泄漏检测
     */
    override fun onCreate() {
        super.onCreate()
        if (LeakCanary.isInAnalyzerProcess(this)) {
            return
        }
        refWatcher = LeakCanary.install(this)
    }


    /**
     *  @companion object 静态代码块
     *  @params:静态属性放置在里面
     *  @constructor:私有化类单例使用
     */

    companion object {

        private lateinit var refWatcher: RefWatcher

        /**
         *  @fuction: 获取RefWatcher实例
         *  @params:null
         */
        fun getRefWatcherInstance(): RefWatcher {
            return refWatcher
        }
    }
}

3.BaseActivity或者BaseFragment的onDestroy()中配置

    
override fun onDestroy() {
        super.onDestroy()
        //将当前activity移除管理栈
        ActivityStack.instance.pull(this)

        /**
         *  @fuction1: 获取refWatche对象
         *  @fuction2:watch() 为观察对象创建弱引用
         *  @params:null
         */
        val refWatcher = PenglaiApplication.getRefWatcherInstance();
        refWatcher.watch(this)
    }

watch()方法的作用是将我们要观察的子类Activity或者Fragment对象创建一个keyedWeakReference弱引用,在后台线程中检查被观察的引用是否被回收,如果没被回收就会触发GC,此时还未被回收,系统会通过HeapAnalyzer分析是否内存泄漏或者泄漏的路径,回传应用显示。

4.代码使用

1.添加读写权限

 
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />


2.MainActivity创建非静态内部类(内存泄漏原因)


 private var handler: Handler? = null

    private fun showLeakCanary() {
        mHandler.sendMessageDelayed(Message.obtain(), 5000)
        try {
            Thread.sleep(2000)
        } catch (e: InterruptedException) {
            e.printStackTrace()
        }
    }

    private val mHandler = object : Handler() {
        override fun handleMessage(msg: Message) {

        }
    }


3.运行项目,Leaks生成以及泄漏日志查看



这是Leak Canary生成的日志,可以通过日志来查找内存泄漏的源头做解决。

猜你喜欢

转载自blog.csdn.net/qq_17470165/article/details/80489305