LeakCanary 2.0后 为什么不需要在application中调用install,跟Application的启动流程有什么关系

LeakCanary 2.0后 为什么不需要在application中调用install

用过 LeakCanary 的都知道,在版本2.0之前需要调用LeakCanary.install()来开启组件的功能以便监听内存泄露。但是在2.0版本之后不需要手动调用了,直接依赖架包就可以使用leak的功能了。这是怎么做到的?难道Leak不需要初始化了?当然不是。要说清这个需要我们先来了解app的启动流程。

Application的启动流程

LeakCanary.png

从图片我们分析app启动流程如下步骤

  • 点击图片的时候launch进程通过binder和AMS通信启动一个activity
  • AMS收到启动的消息后以socket的方式通信Zygote进程fork一个app进程
  • app进程启动后,创建ActivityThread,Looper、Handler对象,开启主线程消息循环Looper.loop()。
  • ActivityThread通过AMS的代理对象ActivityManagerProxy以binder的方式通信AMS
  • AMS接收到信息,调用attachApplication方法
  • AttachApplication方法中,AMS分别通过bindApplication、scheduleLaunchActivity方法,通知APP进程的主线程Handler,对APP进程的Application和Activity进行初始化,并执行Application、Activity的生命周期。

当Activity启动完成后,整个application的启动流程完毕。那么这跟我们的LeakCanary不主动初始化有什么关系呢?

不着急,关键就在bindApplication方法中。来看看bindApplication中的关键代码。

bindApplication中的关键代码

private void handleBindApplication(AppBindData data) {  
   
 VMRuntime.registerSensitiveThread();  
 
  //.........     省略中间代码  
 
if (!data.restrictedBackupMode) {  
               if (!ArrayUtils.isEmpty(data.providers)) {  
                   installContentProviders(app, data.providers);  
                    // For process that contains content providers, we want to  
                    // ensure that the JIT is enabled "at some point".  
                    mH.sendEmptyMessageDelayed(H.ENABLE_JIT, 10*1000);  
                }  
            }  
  
            // Do this after providers, since instrumentation tests generally start their  
            // test thread at this point, and we don't want that racing.  
            try {  
                mInstrumentation.onCreate(data.instrumentationArgs);  
            } catch (Exception e) {  
                throw new RuntimeException(  
                    "Exception thrown in onCreate() of "  
                    + data.instrumentationName + ": " + e.toString(), e);  
            }  
            try {  
                mInstrumentation.callApplicationOnCreate(app);  
            } catch (Exception e) {  
                if (!mInstrumentation.onException(app, e)) {  
                    throw new RuntimeException(  
                      "Unable to create application " + app.getClass().getName()  
                      + ": " + e.toString(), e);  
                }  
            }  
 //.........     省略后面的代码  
}  

仔细看这句代码mInstrumentation.callApplicationOnCreate(app)其实最终调用到了ApplicationonCreate方法之中。往前看你会看到这样一句代码。installContentProviders(app, data.providers) 这句代码实现了ContentProviders的安装,所以app定义的provider都是优先于application的oncreate执行的。

在LeakCanary2.0以后就把初始化方法放在了ContentProvider中。来看看这个provider的实现。

LeakCanary 的初始化位置

在LeakCanary2.0以后就把初始化方法放在了ContentProvider中。来看看这个provider的实现。


internal sealed class AppWatcherInstaller : ContentProvider() {

  /**
   * [MainProcess] automatically sets up the LeakCanary code that runs in the main app process.
   */
  internal class MainProcess : AppWatcherInstaller()

  /**
   * When using the `leakcanary-android-process` artifact instead of `leakcanary-android`,
   * [LeakCanaryProcess] automatically sets up the LeakCanary code
   */
  internal class LeakCanaryProcess : AppWatcherInstaller()

  override fun onCreate(): Boolean {
    val application = context!!.applicationContext as Application
    AppWatcher.manualInstall(application)
    return true
  }
    //......省略其他代码
}

可以看到在onCreate中调用了AppWatcher.manualInstall()来初始化LeakCanary

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容