:)
本文主要是介绍了activity的启动流程,前提是需要了解binder机制(不了解就还是不要往下看了)
流程大概(大概了解就行,后面会详细讲解)
- 当我们调用startActivity (包括activtiy的和context的startActivity),最后都会调用到一个叫做Instrumentation对象的execStartActivity的方法
- 而execStartActivity方法最后调用的是ActivityManagerNative对象的startActivity(ActivityManagerNative其实就是一个binder对象,这个对象就是ActivityManagerService在用户进程的代理)
- 所以startActivity最后调用了ActivityManagerService的代理对象的startActivity方法,实际上就是通过代理调用了ActivityManagerService的startActivity方法(注意:到这里已经切换到系统进程了,ActivityManagerService实际上是在系统进程里面)
- ActivityManagerService的startActivity方法经过了一系列的校验(各种校验),之后调用了一个IApplicationThread(接口)的实例(ApplicationThreadNative)对象的scheduleLaunchActivity方法
- ApplicationThreadNative这个对象其实是用户进程在系统进程里面的一个binder代理对象,用来在系统进程里面返回结果给用户进程
- 当调用scheduleLaunchActivity后用户进程就会根据各种信息将activity创建出来(注意:这个时候已经是用户进程了)
用户进程首先调用了ActivityManagerService的一个binder代理,通知ActivityManagerService创建Activtiy。最后ActivityManagerService会调用一个通知用户进程的binder代理(ApplicationThreadNative),也就是系统进程和用户进程之间的通讯是使用的两个binder
大概流程图
启动一个activity其实是分为两种情况的,一种是Context(ContextImpl)的startActivity方法,一种是Activity的startActivity方法,这两种方法稍有区别。
-
这两种方法的主要一个区别就是context启动的activity是没有任务栈的,可以看到如果intent没有NEW_TASK的话会直接抛一个异常
-
这两种方法最后都是调用到了Instrumentation的execStartActivity方法,而这个Instrumentation就是用来管理activity生命周期的对象,这里面可以看到各种关于生命周期的方法。
不管是通过context还是activity调用startActivity最后都会调用到Instrumentation的execStartActivity
通知ActivityManagerService
-
这里的ActivityManagerNative.getDefault返回的就是一个binder代理(IActivityManager),调用这个之后就到达了系统进程了,也就是调用到了ActivityManagerService的startActivity方法
通知用户进程可以创建activity了
-
通知的方式也是使用的是binder通信,使用的接口是IApplicationThread
用户进程接收到消息
- 用户接收消息是在ActivityThread的内部类ApplicationThread,里面的处理流程比较简单,就是接收到一个消息的时候就用handler发送一个消息出去,然后handler处理消息的时候就是通过Instrumentation来处理的,包括各种生命周期的调用,以及activity的创建
这里就看一个创建的源码吧
- 通过binder调用IApplicationThread的启动方法
-
sendMessage这个方法其实就是ActivityThread里面H的一个消息,在handlerMessage里面最后调用到了mInstrumentation.newActivity
总结
activity的创建过程简单的说就是,用户进程发送一个请求到ActivityManagerService,ActivityManagerService接收到请求之后通过一系列的验证,验证通过之后又发送一个消息到用户进程,这个时候用户进程就开始了创建过程。其实不止创建是这样的,activity的生命周期都是这样的调用的
有好多细节没讲的不清楚,有兴趣的最好是自己去看看吧~ 别人写的永远是别人的 have a good day~