Android-性能优化

LeakCanary

2020-11-02  本文已影响0人  主音King

AppWatcher.Config类,配置是否开启内存检测,支持:Activity、Fragment、FragmentView、ViewModel等四种类型
依赖:

debugImplementation 'com.squareup.leakcanary:leakcanary-android:2.4'

LeakCanary交由AppWatcherInstaller这个ContentProvider自动完成。
ContentProvider会在Application被创建之前由系统调用onCreate()方法来完成初始化,AppWatcherInstaller可以拿到Context来完成初始化并随应用启动。引用方式debugImplementation,正式版本会自动移除LeakCanary所有引用。
Jetpack包含了一组来实现通过ContextProvider来完成初始化的逻辑:AppStartup。Jetpack官方推出AppStartup以后主流。
ObjectWatcher:检测Object内存泄露情况
ActivityDestroyWatcher:检测Activity内存泄露情况
FragmentDestroyWatcher:检测Fragement、FragmentView、ViewModel内存泄露情况。
ActivityDestoryWatcher和FragmentDestroyWatcher都需要依靠ObjectWatcher来完成;Activity、Fragment、FragmentView、ViewModel本质属于不同Object。

ObjectWatcher:检测任意对象

依靠队列ReferenceQueue来实现,在GC过后referenceQueue.poll()返回是否null。WeakReference和ReferenceQueue。被GC回收时,JVM会把弱引用存入与之关联的引用队列之中。
watch()主要逻辑:
1、每个watchedObject生成一个唯一标示key,通过key构建一个watchedObject弱引用KeyedWeakReference,将弱引用保存到watchObjects中。ObjectWatcher可以先后监测多个对象,每个对象会先存入到watchedObjects中
2、外部通过传入的checkRetainedExecutor来指定检测类型触发时机,通过moveToRetained方法来判断是否真的发生了内存泄露,retainedUptimeMillis字段用来标记是否发生了内存泄露。通过onObjectRetainedListeners来分析内存泄露链。

ActivityDestoryWatcher:检测Activity

ActivityDestoryWatcher会向Application注册一个ActivityLifecycleCallbacks回调,收到Activity执行了onDestory的回调,将Activity对象交由ObjectWatcher来进行监听

FragmentDestroyWatch:检测Fragment

上一篇下一篇

猜你喜欢

热点阅读