捋一捋 Android 启动应用进程的前因后果

点击桌面应用图标后

前面(Android 进阶解密阅读笔记2)已经知道启动应用程序进程是由 AMS 向 zygote 进程发起申请,后面由 zygote 进程监听处理。但一般场景下,用户只有点了桌面应用图标才会打开应用,可见 AMS 也是收到了某种响应才会发起申请。在 Android 进阶解密阅读笔记3 中我们知道启动根 Activity 最终会走到 ActivityStackSupervisor 的 startSpecificActivityLocked 方法,而这个方法中的逻辑也包含着启动应用进程,这就是比 AMS 发起创建应用进程请求更早的地方。(以下代码基于 API 28)

void startSpecificActivityLocked(ActivityRecord r,boolean andResume, boolean checkConfig) {
    ProcessRecord app = mService.getProcessRecordLocked(r.processName, r.info.applicationInfo.uid, true);
    //省略...
    if(app != null && app.thread != null) {
        //省略...
        realStartActivityLocked(r, app, andResume, checkConfig);
        return;
    }
    mService.startProcessLocked(r.processName,r.info.applicationInfo, true, 0,"activity", r.intent.getComponent(), false, false,true);
}

大致可见,AMS 根据应用进程的一些信息去获取 ProcessRecord。如果启动根 Activity 时,发现 app 为 null 的话就会调用 AMS 启动应用进程。那在应用进程启动后并调用 ActivityThread 的 main,这个 main 具体又做了什么呢?

ActivityThread 的 main 方法做了什么
public static void main(String[] args) {
    //简单来说 main 方法里创建了主线程的消息循环
    Looper.prepareMainLooper();
    //另外一件事就在这里
    ActivityThread thread = new ActivityThread();
    thread.attach(false, startSeq);
    
    if(sMainThreadHandler == null) {
        sMainThreadHandler = thread.getHandler();
    }
    
    Looper.loop();
}

private void attach(boolean system, long startSeq) {
    final IActivityManager mgr = ActivityManager.getService();
    try {
        //通过 AMS 代理类去绑定应用
        mgr.attachApplication(mAppThread, startSeq);
    } catch(RemoteException ex) {
        throw ex.rethorwFromSystemServer();
    }
}

在 AMS 做了一些逻辑后,又会交还给 Activit

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值