为什么kill前台app会返回到桌面?

本文探讨了Android系统中,当通过AMS.forceStopPackage或app自行调用System.exit(0)杀死前台应用时,为何会返回桌面而不是上一个应用的原因。通过分析AMS的处理逻辑和调用栈,揭示了在app进程被杀后,系统如何调整活动栈,导致回到home stack的过程。
摘要由CSDN通过智能技术生成

最近遇到一个问题,kill掉前台app会返回桌面,为什么不是上一个app呢?

我遇到的杀掉前台进程是有两种方式,一种是系统调用AMS.forceStopPackage; 另一种是app自己调用System.exit(0).

通过打印AMS调用栈能直观看出(基于代码Android O),

1. AMS.forceStopPackage,

04-20 18:34:59.625  3561  3888 D ActivityManager: setFocusStackUnchecked, focusCandidate:ActivityStack{b020eca stackId=0 type=home mode=fullscreen visible=true translucent=true, 1 tasks}
04-20 18:34:59.625  3561  3888 D ActivityManager: java.lang.RuntimeException
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStackSupervisor.setFocusStackUnchecked(ActivityStackSupervisor.java:718)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStack.moveToFront(ActivityStack.java:1057)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStack.moveToFront(ActivityStack.java:1019)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStackSupervisor.moveHomeStackToFront(ActivityStackSupervisor.java:744)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStack.removeTask(ActivityStack.java:5166)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStack.removeActivityFromHistoryLocked(ActivityStack.java:4168)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStack.removeHistoryRecordsForAppLocked(ActivityStack.java:4528)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStack.handleAppDiedLocked(ActivityStack.java:5018)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStackSupervisor.handleAppDiedLocked(ActivityStackSupervisor.java:2155)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityManagerService.handleAppDiedLocked(ActivityManagerService.java:5903)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityManagerService.removeProcessLocked(ActivityManagerService.java:7498)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityManagerService.killPackageProcessesLocked(ActivityManagerService.java:7139)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityManagerService.forceStopPackageLocked(ActivityManagerService.java:7272)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityManagerService.forceStopPackageLocked(ActivityManagerService.java:7051)
04-20 18:34:59.625  3561  3888 D ActivityManager:     at com.android.server.am.ActivityManagerService.forceStopPackage(ActivityManagerService.java:6851)

同时贴下resume的调用栈

04-20 18:34:59.629  3561  3888 D ActivityManager: resumeTopActivityInnerLocked->next ActivityRecode:ActivityRecord{f16f467 u0 com.xxx.home/.MainActivity t1}
04-20 18:34:59.629  3561  3888 D ActivityManager: java.lang.RuntimeException
04-20 18:34:59.629  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStack.resumeTopActivityInnerLocked(ActivityStack.java:2349)
04-20 18:34:59.629  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStack.resumeTopActivityUncheckedLocked(ActivityStack.java:2300)
04-20 18:34:59.629  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStackSupervisor.resumeFocusedStackTopActivityLocked(ActivityStackSupervisor.java:2259)
04-20 18:34:59.629  3561  3888 D ActivityManager:     at com.android.server.am.ActivityStackSupervisor.resumeFocusedStackTopActivityLocked(ActivityStackSupervisor.java:2240)
04-20 18:34:59.629  3561  3888 D ActivityManager:     at com.android.server.am.ActivityManagerService.handleAppDiedLocked(ActivityManagerService.java:5920)
04-20 18:34:59.629  3561  3888 D ActivityManager:     at com.android.server.am.ActivityManagerService.removeProcessLocked(Activity
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值