Android `startActivity` 流程分析

1. 应用进程侧:发起启动请求

1.1 ContextWrapper.startActivity()

  • 调用入口Activity 继承自 ContextWrapper,调用 startActivity() 方法。

  • 源码路径frameworks/base/core/java/android/content/ContextWrapper.java

    java 复制代码
    @Override
    public void startActivity(Intent intent) {
        mBase.startActivity(intent); // mBase 是 ContextImpl 实例
    }

1.2 ContextImpl.startActivity()

  • 核心实现 :通过 Instrumentation 执行启动逻辑。

  • 源码路径frameworks/base/core/java/android/app/ContextImpl.java

    typescript 复制代码
    @Override
    public void startActivity(Intent intent, Bundle options) {
        // 检查权限和 Intent 合法性
        mMainThread.getInstrumentation().execStartActivity(
            getOuterContext(), mMainThread.getApplicationThread(), 
            null, (Activity) null, intent, -1, options
        );
    }

1.3 Instrumentation.execStartActivity()

  • 关键角色:监控 Activity 生命周期,通过 Binder 与 AMS 通信。

  • 源码路径frameworks/base/core/java/android/app/Instrumentation.java

    scss 复制代码
    public ActivityResult execStartActivity(...) {
        // 获取 AMS 的 Binder 代理对象 IActivityTaskManager
        int result = ActivityTaskManager.getService().startActivity(...);
        // 检查启动结果(例如 ActivityNotFound 异常)
        checkStartActivityResult(result, intent);
    }

2. 系统服务进程(AMS):处理启动逻辑

2.1 ActivityTaskManagerService.startActivity()

  • 入口方法:处理来自应用进程的跨进程请求。

  • 源码路径frameworks/base/services/core/java/com/android/server/wm/ActivityTaskManagerService.java

    java 复制代码
    @Override
    public final int startActivity(...) {
        // 委托给 ActivityStarter 处理
        return getActivityStartController().obtainStarter(intent, "startActivity").execute();
    }

2.2 ActivityStarter.execute()

  • 核心逻辑:处理启动模式、权限校验、Intent 解析等。

  • 源码路径frameworks/base/services/core/java/com/android/server/wm/ActivityStarter.java

    scss 复制代码
    int execute() {
        // Step 1: 解析 Intent 并验证
        ResolveInfo rInfo = mService.resolveIntent(...);
        ActivityInfo aInfo = mSupervisor.resolveActivity(...);
        
        // Step 2: 权限校验(包括 manifest 权限和运行时权限)
        int grantResult = checkTargetPermissions(...);
        
        // Step 3: 创建 ActivityRecord(代表一个 Activity 实例)
        final ActivityRecord r = new ActivityRecord(...);
        
        // Step 4: 处理启动模式(FLAG_ACTIVITY_XXX)
        return startActivityUnchecked(r, sourceRecord, ...);
    }

2.3 ActivityStarter.startActivityUnchecked()

  • 关键逻辑:处理任务栈复用逻辑。

    scss 复制代码
    private int startActivityUnchecked(...) {
        // 根据 launchMode 和 Intent.FLAG 计算目标栈
        TargetStack = computeTargetStack();
        
        // 处理 "singleTask" 或 "singleInstance" 模式
        if (r.launchMode == LAUNCH_SINGLE_TASK) {
            reuseOrCreateNewTask(r, targetStack);
        }
        
        // 将 ActivityRecord 添加到栈顶
        targetStack.startActivityLocked(r, newTask, ...);
    }

2.4 ActivityStackSupervisor.startSpecificActivity()

  • 进程管理:决定是否创建新进程或复用已有进程。

  • 源码路径frameworks/base/services/core/java/com/android/server/wm/ActivityStackSupervisor.java

    scss 复制代码
    void startSpecificActivity(ActivityRecord r) {
        // 检查目标进程是否存在
        WindowProcessController app = mService.getProcessController(...);
        if (app != null && app.hasThread()) {
            // 进程已存在:直接启动 Activity
            realStartActivityLocked(r, app, ...);
        } else {
            // 进程不存在:创建新进程(通过 Zygote)
            mService.startProcessAsync(...);
        }
    }

3. 目标应用进程:创建并启动 Activity

3.1 ApplicationThread.scheduleLaunchActivity()

  • 跨进程通信 :AMS 通过 Binder 调用应用进程的 ApplicationThread

  • 源码路径frameworks/base/core/java/android/app/ActivityThread.java

    scala 复制代码
    private class ApplicationThread extends IApplicationThread.Stub {
        @Override
        public void scheduleLaunchActivity(...) {
            sendMessage(H.LAUNCH_ACTIVITY, r);
        }
    }

3.2 ActivityThread.H.handleMessage()

  • 主线程调度 :通过 Handler 切换到主线程处理消息。

    scala 复制代码
    class H extends Handler {
        public void handleMessage(Message msg) {
            switch (msg.what) {
                case LAUNCH_ACTIVITY:
                    handleLaunchActivity((ActivityClientRecord) msg.obj);
                    break;
            }
        }
    }

3.3 ActivityThread.handleLaunchActivity()

  • 创建 Activity 实例:反射调用构造函数,绑定 Context。

    scss 复制代码
    private void handleLaunchActivity(...) {
        // 创建 Activity 实例
        final Activity a = performLaunchActivity(r, customIntent);
        
        // 触发 onResume()
        handleResumeActivity(r.token, ...);
    }

3.4 ActivityThread.performLaunchActivity()

  • 生命周期触发 :调用 onCreate()onStart() 等方法。

    scss 复制代码
    private Activity performLaunchActivity(...) {
        // 反射创建 Activity 实例
        java.lang.ClassLoader cl = appContext.getClassLoader();
        Activity activity = mInstrumentation.newActivity(cl, component.getClassName(), r.intent);
        
        // 绑定 Context 和 Window
        activity.attach(appContext, ..., r.token);
        
        // 调用 onCreate()
        if (r.isPersistable()) {
            mInstrumentation.callActivityOnCreate(activity, r.state, r.persistentState);
        } else {
            mInstrumentation.callActivityOnCreate(activity, r.state);
        }
        
        // 调用 onStart()
        activity.performStart();
    }

4. 关键类

类名 职责描述
Instrumentation 监控应用与系统的交互,如 Activity 生命周期和启动流程。
ActivityTaskManagerService 管理所有 Activity 的任务栈和生命周期状态。
ActivityStarter 处理启动参数(Intent、Flag、权限校验等),生成启动策略。
ActivityStackSupervisor 管理多个 ActivityStack,协调栈之间的交互。
ActivityRecord 描述一个 Activity 实例的元数据(如配置、状态等)。
ApplicationThread 应用进程与 AMS 通信的 Binder 桥梁,接收 AMS 的跨进程调用。

5.时序图

sequenceDiagram participant App as 应用进程 participant AMS as AMS 进程 participant Target as 目标进程 App->>App: 1. Activity.startActivity() App->>App: 2. ContextImpl.startActivity() App->>App: 3. Instrumentation.execStartActivity() App->>AMS: 4. IActivityTaskManager.startActivity() (Binder IPC) AMS->>AMS: 5. ActivityTaskManagerService.startActivity() AMS->>AMS: 6. ActivityStartController.obtainStarter() AMS->>AMS: 7. ActivityStarter.execute() AMS->>AMS: 8. 解析 Intent/权限校验 AMS->>AMS: 9. ActivityStackSupervisor.startSpecificActivity() alt 目标进程已存在 AMS->>Target: 10. ApplicationThread.scheduleLaunchActivity() (Binder IPC) else 目标进程不存在 AMS->>AMS: 10. 创建新进程 (Zygote fork) AMS->>Target: 11. 初始化 ActivityThread.main() AMS->>Target: 12. ApplicationThread.scheduleLaunchActivity() end Target->>Target: 13. H.handleMessage(LAUNCH_ACTIVITY) Target->>Target: 14. ActivityThread.handleLaunchActivity() Target->>Target: 15. performLaunchActivity() Target->>Target: 16. Instrumentation.newActivity() Target->>Target: 17. Activity.attach() Target->>Target: 18. Instrumentation.callActivityOnCreate() Target->>Target: 19. Activity.performStart() Target->>Target: 20. handleResumeActivity() Target->>Target: 21. WindowManager.addView()

6. 总结

startActivity 的完整流程可概括为 跨进程协作的三段式架构

  1. 应用进程发起请求
    • 通过 Instrumentation 封装启动逻辑,经 Binder 将请求转发至 AMS。
  2. AMS 决策与调度
    • 校验权限、解析 Intent、处理启动模式和任务栈,决定是否创建新进程或复用现有组件。
  3. 目标进程执行创建
    • 通过 ApplicationThread 回调到应用主线程,反射创建 Activity 实例并触发生命周期。
相关推荐
Libraeking11 小时前
破壁行动:在旧项目中丝滑嵌入 Compose(混合开发实战)
android·经验分享·android jetpack
市场部需要一个软件开发岗位11 小时前
JAVA开发常见安全问题:Cookie 中明文存储用户名、密码
android·java·安全
JMchen12313 小时前
Android后台服务与网络保活:WorkManager的实战应用
android·java·网络·kotlin·php·android-studio
crmscs14 小时前
剪映永久解锁版/电脑版永久会员VIP/安卓SVIP手机永久版下载
android·智能手机·电脑
localbob14 小时前
杀戮尖塔 v6 MOD整合版(Slay the Spire)安卓+PC端免安装中文版分享 卡牌肉鸽神作!杀戮尖塔中文版,电脑和手机都能玩!杀戮尖塔.exe 杀戮尖塔.apk
android·杀戮尖塔apk·杀戮尖塔exe·游戏分享
机建狂魔14 小时前
手机秒变电影机:Blackmagic Camera + LUT滤镜包的专业级视频解决方案
android·拍照·摄影·lut滤镜·拍摄·摄像·录像
hudawei99614 小时前
flutter和Android动画的对比
android·flutter·动画
lxysbly16 小时前
md模拟器安卓版带金手指2026
android
儿歌八万首16 小时前
硬核春节:用 Compose 打造“赛博鞭炮”
android·kotlin·compose·春节
消失的旧时光-194319 小时前
从 Kotlin 到 Dart:为什么 sealed 是处理「多种返回结果」的最佳方式?
android·开发语言·flutter·架构·kotlin·sealed