Android中常见的Bug

2019-04-14 12:20发布


CPPAlien的专栏 .

[原]从Installer直接打开应用程序会出现Android系统bug

问题现象:

用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则不进行重复创建。