am启动一个activity
在前面先作一个精简的总结
从上图说起,上图分析到为Activity所在进程zygote一个进程,其实zygote一个进程,就是为其分配私有空间,分配一个process_id,ProcessRecord(应该相当于进程描述符吧)。随意此图没有涉及到Activity的内容。那么接下来,简要的分析流程中的每个方法的作用:
ActivityManagerService#startActivityAndWait()
该方法主要是传入了一些启动一个activity需要的参数,然后把这些参数再给ActivityStack#startActivityAndMayWait()
ActivityStack#startActivityAndMayWait()
ActivityStack是ActivityManagerService的一个成员:mMainStack,目前的Android系统版本,ActivityStack只有一个。
* 使用ActivityStack(在高版本的API中是ActivityStackSupervisor)#resolveActivity(...),PKMS根据Intent去得到一个ActivityInfo,ActivityInfo代表了一个Activity的信息,存放了在
Manifest中注册的各种属性,在隐式调用使可能匹配这个intent的activity很多,但是会选一个最匹配,因为只能启动一个。
* 获取调用者(IApplicationThread)的pid和uid,IApplicationThread是ActivityThread持有的,所以就是获取启动该Activity的应用进程的pid和uid。但是如果
不是应用进程启动的话,如是am.java脚本启动的,那么就会获取调用该方法的所在进程的pid和uid。
* 调用ActivityStack(在高版本的API中是ActivityStackSupervisor)#startActivityLocked(...),该方法涉及到了处理startActivityResult的东西,调用者,
返回result接收者,requestCode等。后续会继续总结这个方法。
* 因为在使用am.java启动Activity是