总结:

Activity的启动过程,我们可以从ContextstartActivity说起,其实现是ContextImplstartActivity(内部调用startActivityForResult),然后内部会通过Instrumentation来尝试启动Activity,这是一个跨进程过程,它会调用ams的startActivity方法,当ams校验完activity的合法性后,会通过ApplicationThread回调到我们的进程,这也是一次跨进程过程,而applicationThread就是一个binder,回调逻辑是在binder线程池中完成的,所以需要通过Handler H将其切换到ui线程,第一个消息是LAUNCH_ACTIVITY,它对应handleLaunchActivity,在这个方法里完成了Activity的创建和启动,接着,在activity的onResume中,activity的内容将开始渲染到window上,然后开始绘制直到我们看见

流程

  1. Launcher进程请求AMS
  2. AMS发送创建应用进程请求
  3. Zygote进程接受请求并孵化应用进程
  4. 应用进程启动ActivityThread
  5. 应用进程绑定到AMS
  6. AMS发送启动Activity的请求
  7. ActivityThreadHandler处理启动Activity的请求

Q&A

Instrumentation是在任何应用程序运行前进行初始化的,可以用它来检测系统和应用程序间的交互。每一个activity都会持有instrumentation的引用,但是整个进程只有一个instrumentation实例,instrumentation相当于一个大管家,管理着activity和application的生命周期,包括activity的创建。

  1. 无论是通过Launcher启动,还是通过activity 内部来调用startActivity接口 来启动新的activity,都是通过Binder进程间通信进入到AMS进程中,并且调用AMS.startActivity 接口
  2. AMS调用 ActivityStack.startActivityMayWait来做准备要启动的activity的相关信息
  3. ActivityStack通知 ApplicationThread 要进行Activity 启动调度了,这里的ApplicationThread代表要调用 AMS.startActivity接口的进程,对于通过点击应用图标来说的情景来说,这个进程就是launcher了,而对于通过内部调用activity来说,这个进程就是activity 所在的进程
  4. ApplicationThread 不执行真正的启动操作,他通过调用AMS.activityPaused接口进入到AMS进程中,看看是否需要创建新的进程来启动activity
  5. 对于通过点击应用图标启动activity的场景说,AMS在这一步中没回调用startProcessLocked来创建一个新的进程,而对于通过在内部启动新的activity来说,这一步不需要执行,因为新的activity就在原来的activity所在的进程中启动
  6. AMS调用 ApplicationThread.scheduleLaunchActivity接口,通知相应的进程执行启动activity的操作
  7. ApplicationThread把这个启动activity的操作转发给ActivityThread,activityThread通过classLoader导入相应的activity类,然后把它启动起来
  8. ActivityThread:主线程、UI线程,程序的入口(main函数),不是线程是运行在主线程中的一个对象。
  9. ApplicationThread是ActivityThread和AMS交互的中间桥梁。
  10. ApplicationThread 和ActivityThread之间的联系是通过Handler,ActivityThread的变量final H mH = new H(); 私有内部类H继承自Handler,是主线程的handler,处理一些消息事务。
  11. 关于ApplicationThread: 是ActivityThread的私有变量,也是一个Binder对象,ApplicationThread是Client端的Binder,里面有操作scheduleXX方法处理四大组件的生命周期方法,所以AMS(AMS是Android系统最为核心的服务之一,其职责包括四大核心组件与进程的管理)服务想要调用启动组件,那就必须持有ApplicationThread的实例,如调用ApplicationThread的scheduleLaunchActivity方法,最后在scheduleLaunchActivity方法中sendMessage方法发送消息,ActivityThread中处理消息。

从Launcher启动activity

首先Launcher进程向AMS请求创建根Activity,AMS会判断根Activity所需的应用程序进程是否存在并启动,如果不存在就会请求Zygote进程创建应用程序进程。应用程序进程启动后,AMS会请求应用程序进程创建并启动根Activity。

android的activity启动流程分析 activity启动流程简述_主线程

app内的Activity启动:

android的activity启动流程分析 activity启动流程简述_ui_02