当ContentProvider所在的进程未启动时,第一次访问它时,就会触发ContentProvider的创建,这也伴随着ContentProvider所在进程的启动,而ContentProvider中四个方法的任何一个都会触发ContentProvider的启动过程。
1、通过acquireProvider()来获取ContentProvider
内部直接调用ActivityThread的acquireProvider方法。2、ActivityThread的acquireProvider()
如果目前ContentProvider启动了就直接返回,若没有启动,那么就发送一个进程间请求给ActivityManagerService让其启动ContentProvider,最后再通过installProvider来修改引用计数。3、启动进程由ActivityManagerService的startProcessLocked方法来完成
内部通过Process的start方法完成一个新进程的启动,新进程启动后其入口方法为ActivityThread的main方法。4、ActivityThread的main方法
内部会创建ActivityThread的实例并调用attach方法来进行一些初始化。5、ActivityThread的attach方法
通过ActivityManagerService的attachApplication()->attachApplicationLocked()->bindApplication()。6、bindApplication()会发送一个BIND_APPLICATION消息
当Handler接收到这个消息后,会调用ActivityThread的handleBindApplication方法。7、handleBindApplication()完成Application和ContentProvider的创建
1)创建ContextImpl和Instrumentation2)创建Application对象
3)启动当前进程的ContentProvider并调用其onCreate():在installProvier方法中通过类加载器完成ContentProvider对象的创建,到此ContentProvider已经启动完成了。
4)调用Application的onCreate()
以上四个步骤完成,获取到的ContentProvider是ContentProvider的Binder对象IContentProvider,IContentProvider的具体实现是ContentProviderNative和ContentProvider.Transport,因此其他应用调用IContentProvider的query方法时,最终会一进程间通信的方式调用ContentProvider.Transport的query方法。
注意:
当ContentProvider所在的进程启动时,ContentProvider的onCreate要先于Application的onCreate执行。