先将当前的Activity走到pause
开始startActivity 会走startActivityForResult 方法,这里的-1表示当前不需要知道Acticity的启动结果
startActivity 如果是Launcher的话就肯定为parent为空,如果是Activity跳Activity就不为空,那么我们来分析一下Launch启动Activity的流程,接下来调用Instrumentation 的
紧接着调用了Instrumentation 的 execStartActivity 方法
通过ActivityTaskManager.getService对象来获取AMS代理对象 getService调用了startActivity,当获取到结果后进行check
这里有个技巧,如果当前的代码权限不足,会抛出异常来终止调用
ActivityStarter 是 Android 8.0 中新增的类,它主要负责启动 Activity 的操作。在 Android 8.0 之前,Activity 的启动是在 ActivityManagerService 中完成的,但是随着 Android 系统的复杂性增加,Activity 的启动也变得越来越复杂,因此需要一个专门的类来处理 Activity 的启动过程。
ActivityStarter 主要负责以下几个方面的工作:
-
处理 Activity 启动请求,包括解析 Intent、选择合适的 Activity、处理权限等。
-
处理 Activity 启动时的各种参数,如 flags、options 和 launchBounds 等。
-
管理 Activity 启动时的状态,如等待启动、正在启动、已启动等。
-
监听 Activity 启动时的状态变化,如启动成功、启动失败、被取消等。
总之,ActivityStarter 的作用是使 Activity 启动过程更加灵活、可控和可扩展。
如果调用者的进程被隔离,则抛出异常
接下来会调用到 ActivityStarter 的 startActivityMayWait 方法
在内部调用到了startActivityLocked
接着调用到ActivityStarter 的 startActivity
紧接着会调用resumeFocusedStackTopActivityLocked
这个时候就会回到启动Activity的进程启动一个Activity
ApplicationThread::scheduleLaunchActivity
Activity加载流程仍需补充,Acticity跨进程通讯仍需补充