记一个Android Installer的bug

来源:互联网 发布:自建app软件 编辑:程序博客网 时间:2024/05/30 19:32

此Bug,经测试截止到Android在5.0版本上都还没有解决。并且一些大厂的APP,比如新浪微博都会有此问题。

问题现象:
用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则不进行重复创建。

详情点击:http://www.apkbus.com/forum.php?mod=viewthread&tid=251929&extra=page%3D1&_dsign=2a4e40c3



0 0
原创粉丝点击