最近遇到一个问题,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