揭秘最新android studio instant run(一
问题引出
android studio 3.0之后的instant run和2.0有了一些变化,其中一个变化便是2.0的时候需要生成一个BootStrapApplication,在其中执行一些classloader的初始化和委托工作等等(具体我就不展开了,这篇文章写的不错深入理解Android Instant Run运行机制),但是3.0之后去掉了, 多了一个InstantRunContentProvider,源码里面是这样说的
/**
* Content Provider that abuses a quirk of early Android initialization to start the instant run
* service very early, before Application.onCreate(): content providers get initialized before
* Application.onCreate() is called.
*
* ActivityThread initializes the application by creating and binding the Application object,
* which we don't want to replace right now, creating content providers, and _then_ calling
* Application.onCreate(), so by starting the IR server in the ContentProvider, we initialize
* early without risking the ANR we'd get by doing an explicit service start.
*
* A ContentProvider also simplifies the client code, which doesn't have to do anything special
* (like am startservice) in order to cause the instant run server to start on
* application startup.
*/
大意就是既然ContentProvider的初始化是先于Application.onCreate(),那我就在content providers 的oncreate里面做一些事情好了,于是我们可以看到
data:image/s3,"s3://crabby-images/02e1c/02e1c64d895958ba6d2103efa9944a38f861e09c" alt=""
此处执行了server的create函数。好了,我们的开篇就到这里,第一个问题就是:ContentProvider的初始化真的先于Application 么?
接下来我们就从源码和实践两个方面验证一下,
一、首先看下源码
对于Activity的启动流程,很多文章也讲过,这里也不再赘述,以找到我们问题的答案为主,一切从ActivityThread的main函数入手:
1.<ActivityThread> attach
data:image/s3,"s3://crabby-images/c6351/c635110b802dc63d35e035b413c9f1cd4f7defff" alt=""
2.<ActivityThread> attachApplication
data:image/s3,"s3://crabby-images/9956d/9956d15abe950bd222c74f8b9ae5a21a2d0e19c3" alt=""
3.<ActivityManagerService> attachApplication
data:image/s3,"s3://crabby-images/666cd/666cd7ffade88c0c63a51bcd20479cb92b69648f" alt=""
你是不是想问ActivityManagerService和IActivityManager的关系?这里先不说,大家看文末的源码,查看下ActivityManagerService的继承关系就明白了
4.<ActivityManagerService> attachApplicationLocked
data:image/s3,"s3://crabby-images/3fa67/3fa679f6a915ef54797634fd6d8468b2a2e9b6f1" alt=""
这个函数比较长,我截个开头,然后截一段后面的关键
data:image/s3,"s3://crabby-images/f6cfb/f6cfb31cc85c117dbdb818a4c46a0bf96415b3f4" alt=""
5.<ActivityThread> bindApplication
data:image/s3,"s3://crabby-images/0d6d9/0d6d954bb440ac518c90d150ea0a1c34df01702c" alt=""
这个函数比较长,我截个开头,然后截一段后面的关键
data:image/s3,"s3://crabby-images/85cc1/85cc1946dcd4c628ad7f69ad51b301eccf147a8a" alt=""
此处发了个消息交给handler处理了, 继续截图
data:image/s3,"s3://crabby-images/706f6/706f61cdf6d8742d47f82a51fd45b65dfc1ece19" alt=""
6.<ActivityThread> handleBindApplication
data:image/s3,"s3://crabby-images/e55ad/e55adedb716f5544b62248e229038a7a6544ecbd" alt=""
********************************我是分割线***********************************************************
第六点这里就是本文的关键了,此处表明ContentProvider的onCreate确实是先于Application的的onCreate执行的。
当然你说我没看到onCreate啊,别急下面的截图为你诠释,展开installContentProviders和callApplicationOnCreate最终会看到oncreate的
********************************我是分割线***********************************************************
7.<ActivityThread> installContentProviders installProvider
data:image/s3,"s3://crabby-images/348f1/348f1fc2071cfc9c60cd89ddd1638845182be041" alt=""
installProvider
data:image/s3,"s3://crabby-images/7638f/7638fe6069210d3cd954d4b9f4b4d6a1334438a6" alt=""
attachInfo
data:image/s3,"s3://crabby-images/d00fd/d00fd8582b918e7c7e449d88cb238851bdd37bda" alt=""
8.<Instrumentation> callApplicationOnCreate
data:image/s3,"s3://crabby-images/d10e0/d10e01942771b9a04420b41247800ceb7cc913b8" alt=""
二、实践验证
首先我们再看一遍InstantRunContentProvider的onCreate方法
data:image/s3,"s3://crabby-images/02e1c/02e1c64d895958ba6d2103efa9944a38f861e09c" alt=""
好了,既然谷歌大神已经在这里打了日志了,真是天助我也,验证就变得异常简单了,我们只需要新建一个工程,开启instant run,然后新建一个Application,在其中的onCreate方法中打个日志,看下二者的时间先后即可,我的Application里面的代码如下,
data:image/s3,"s3://crabby-images/42479/42479cf4d0129bb0e320110323ef03f83108590d" alt=""
验证结果如下:
data:image/s3,"s3://crabby-images/c9d5d/c9d5d3830a9d70964822072a42b0b8d3e8df9f8f" alt=""
验证的结果也表明确实ContentProvider的初始化真的先于Application,好了,揭秘最新android studio instant run(一)就到这里了,喜欢的朋友帮忙点赞哦