APP启动流程

一、APP启动流程

涉及到 四个进程的通信,分别是 launcher进程、AMS所在的SystemServer进程、Zygote进程、用户app进程

概览步骤:

1、launcher作为一个APP,点击图标后,也触发startActivity了,由于与用户进程是不同的,所以通过ServiceManager获取AMS的binder引用,从而可以访问AMS(ServiceManager是一个独立进程,它存储了所有APP所需要的binder引用,而且它的地址是固定的)

2、AMS会查询对应的activity栈信息,如果进程不存在,则通过socket通信方式通知Zygote进程去fork新进程。

3、APP进程创建后会通知AMS 。

4、AMS 收到信息会继续通知APP去创建Application,并且接下来会通知application去拉起activity。

5、APP进程依次收到通知后,会依次完成加载apk,初始化application,执行activity生命周期。


APP启动流程图



launcher启动APP流程

二、AMS通知Zygote创建APP过程

1、AMS内部执行逻辑

(1)ActivityTaskManagerService掉用startProcessAsync方法去创建APP进程,是异步的,通过handler交给startProcess方法

(2)然后通知Processlist.startProcessLocked方法,这个方法会构造一个对象ProcessRecord对象,然后将各种信息添加到这个对象中。

(3)接下来调用Processlist.startProcessLocked方法,这个方法主要负责把各种信息转换为runtimeFlags标记位,连同上面构造的ProcessRecord继续传递给下层。

(4)最终通知Process.start方法,交给zygoteProcess.start方法,最终传递给startViaZygote方法。

2、Zygote进程逻辑

(1)Zygote进程创建后,最开始入口是在C层,app_main.cpp文件的main方法,最终会调用AndroidRuntime.cpp中的start函数,去启动JVM虚拟机

(2)创建虚拟机后,进行jni方法注册,然后通过native层反射找到ZygoteInit的main函数并执行。

(3)ZygoteInit的main方法中,会做几件事:

把自身进程ID 设置为0,并且没有父进程

会进行一系列的初始化操作,preload方法中

如果是首次执行,则会forkSystemServer,AMS ,WMS 都属于SystemServer进程

会创建serverSocket,调用runLoop,监听AMS传递过来的消息。

(4)收到通知后fork产生APP进程

(5)调用ActivityThread.main方法

3、APP进程创建和初始化过程

APP创建初始化操作比较简单,主要做了两件事,初始化looper,以及通知AMS(注意,此时只是APP进程创建了,但是还没有加载apk中的任何类)

(1)初始化主线程looper,开启循环

(2)通知AMS   attach方法,通过binder通知AMS,并且把自身的binder(ApplicationThread)也传递给AMS

AMS的binder是直接通过ServiceManager的方式获取的,ServiceManager存储了所有的binder引用,AMS在启动的时候去注册

4、AMS通知APP进程进行各种生命周期操作

ActivityManagerService的attachApplication 方法会受到APP传递过来的消息,然后交友attachApplicationLocked处理。

(1)attachApplicationLocked主要做了两件事:

通知APP进程初始化操作

进行一系列操作,拉起APP首页


(2)handler交给HandleBindApplication去完成APP初始化逻辑的过程

使用ClassLoader去加载apk中的dex文件

加载apk中的资源

反射生成application类,调用attachBaseApplication方法

调用application的onCreate方法

(3)AMS中处理Activity启动逻辑

ActivityManagerService.attachApplicationLocked->

ActivityTaskManagerService.LocalService.attachApplication->

RootWindowContainer.attachApplication->

RootWindowContainer.startActivityForAttachedApplicationIfNeeded->

ActivityTaskSupervisor.realStartActivityLocked

realStartActivityLocked中创建Activity的生命周期事务,最终通过ClientLifecycleManager.scheduleTransaction通过binder发送到APP进程的ApplicationThread.scheduleTransaction方法中,则AMS流程就完成了。

FAQ:

问:AMS 通知APP进程初始化过程中,为什么不会出现先加载Activity,然后再去初始化应用呢?

答:因为无论初始化APP,还是拉起activity,最终都是交给handler切换到主线程处理,所以即便初始化APP时耗时操作,拉起activity的msg也得等前面的消息执行完后才执行。

参考资料:

https://juejin.cn/post/7231439815647789113

https://blog.csdn.net/rzleilei/article/details/125665839

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容