问题现象:
用Android系统自带的Installer安装完应用后,会有以下两个不同表现:
1,用户直接在installer界面打开应用。然后按home键后台运行,此时如果再点击该应用的launcher图标或者快捷方式进入,会发现该应用又会从该应用第一个页面重新开始启动。
2,用户在installer界面安装完后,直接点击完成,然后找到launcher图标点击启动应用。此时按home键后台,再次点击图标进入,发现应用会呈现上次按home键前呈现的Activity。
测试实验:
经测试发现,只要是从一个应用去启动另一个应用,都会有此问题,以下我会用一个例子说明。
现有App1和App2.
App1中有一个Activity,有如下代码去打开App2.
PackageManager packageManager = getPackageManager();
Intent intent;
intent = packageManager.getLaunchIntentForPackage("cc.ninty.app2");
if(intent==null){
System.out.println("APP not found!");
}
startActivity(intent);
App2中有两个Activity,Activity1和Activity2,用Activity1去自动startActivity2.
以上三个Activity的launch mode都为默认的standard。此时执行App1,并监控这三个Activity的taskid。
可以发现通过App1启动的App2中的两个Activity的taskid与App1不同,并且以后每次点击APP2的launcher图标都会发现Activity1和Activity2又会被重新创建一次,并且taskid与前一次相同。
问题原因:
Android从最初开始一直有次bug并且一直未修复,以下是找的一些资料。
https://code.google.com/p/android/issues/detail?id=2373
https://code.google.com/p/android/issues/detail?id=26658
http://stackoverflow.com/questions/16283079/re-launch-of-activity-on-home-button-but-only-the-first-time/16447508#16447508
规避方案:
因第二次通过launcher或者快捷方式启动应用,会重新创建Activity1,但此时的Activity1不是该task的root(也即该task第一个拥有的activity),所以可以通过在Activity1的onCreate方法中写以下判断:
if ( !isTaskRoot() ) {
finish();
return;
}
表示如果task中还有其他Activity则不进行重复创建。