一,问题
遇到这样一个问题:用户反馈点击home键之后,再次打开会进入登录界面,要求重新输入密码。
这里有两个问题:
一是只有部分机型会出现这个问题;
二是为什么会出现这个问题
二,解决
经过测试发现,对于出现问题的机器,重新打开app进入登录界面后,按后退键,就可以回到按home键之前的界面。
这说明点击app之后,重新创建了登录Activity的实例。
找到问题之后,就容易解决了。
在LoginActivity的onCreate方法的setContentView调用之前加入如下代码:
if (intent.flags and Intent.FLAG_ACTIVITY_BROUGHT_TO_FRONT != 0) {
finish()
return
}
三,深入探讨
第一部分所说的只有部分机型出现这个问题是不准确的,实际上是只有安装后就打开app,然后一直不退出,才会出现这个问题。
换句话说,如果用户安装后直接从安装界面打开app,然后不是按home键回到桌面,而是直接退出app。之后就不会出现这个问题了。
要理解这个问题,需要我们了解启动标志【FLAG_ACTIVITY_BROUGHT_TO_FRONT】的作用。
如果Intent中有FLAG_ACTIVITY_BROUGHT_TO_FRONT 这个flag,则重新打开Activity时,如果栈中已经存在该Activity,则该Activity会被推到栈顶。但前提是第一次启动Activity和之后启动这个Activity的Intent的内容要相同,否则,将会启动一个新的Activity。
而从安装界面启动Activity和从桌面点击快捷方式启动Activity时所使用的Intent是不一样的,从安装界面启动Activity时会调用setPackage方法,而从桌面启动是不会调用这个方法的。
也即是说从安装界面启动Activity的Intent比从桌面启动的Intent多了packageName信息。
所以LoginActity会被创建多次。