版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/zuo_er_lyf/article/details/89491133
问题:
在一次app测试中,偶然发现打开项目按下home键,回到桌面,再次点击app图标,进入app,切换之前的页面突然退出,回到了首页,开始以为是该页面出现bug崩溃了,查看日志,并未发现错误日志,于是在页面的生命周期方法中,写上log,再次重复了上述操作,进入app后,页面一样的退出,查看log,当前页执行Resume()方法后,再次执行了Destroyed()方法,切换了其他页面,发现都会退出,于是在Application文件中的onCreate()中,监听所有页面的生命周期,方法如下:
registerActivityLifecycleCallbacks(new ActivityLifecycleCallbacks() {
@Override
public void onActivityStopped(Activity activity) {
Log.v("viclee", activity + "onActivityStopped");
count--;
if (count == 0) {
Log.v("viclee", ">>>>>>>>>>>>>>>>>>>切到后台 lifecycle");
}
}
@Override
public void onActivityStarted(Activity activity) {
Log.v("viclee", activity + "onActivityStarted");
if (count == 0) {
Log.v("viclee", ">>>>>>>>>>>>>>>>>>>切到前台 lifecycle");
}
count++;
}
@Override
public void onActivitySaveInstanceState(Activity activity, Bundle outState) {
Log.v("viclee", activity + "onActivitySaveInstanceState");
}
@Override
public void onActivityResumed(Activity activity) {
Log.v("viclee", activity + "onActivityResumed");
}
@Override
public void onActivityPaused(Activity activity) {
Log.v("viclee", activity + "onActivityPaused");
}
@Override
public void onActivityDestroyed(Activity activity) {
Log.v("viclee", activity + "onActivityDestroyed");
}
@Override
public void onActivityCreated(Activity activity, Bundle savedInstanceState) {
Log.v("viclee", activity + "onActivityCreated");
}
});
再次执行后台切换前台操作,发现打印的日志如下:
发下启动页(WelcomeActivity)竟然启动了,当前页执行了退出操作(Destroyed)。
原因:
app启动的过程有两种情况,第一种是从桌面launcher上点击相应的应用图标,第二种是在activity中通过调用startActivity来启动一个新的activity。上述的问题,刚好属于第一种,启动情况,当我们点击应用图标的时候,会重新启动app,启动新的堆栈,清除之前的堆栈,所以之前开启的页面都会被清除。
解决方法:
在启动页的onCreate()方法中加入:
if((getIntent().getFlags() & Intent.FLAG_ACTIVITY_BROUGHT_TO_FRONT) != 0){
finish();
return;
}
因为启动每一个activity会在intent中设置一个flag,详情需要了解app的启动过程。
设置之后再看下生命周期的log:
发现启动页再次启动后,立即执行Destroyed方法,return阻止了后续的操作,也就保留了当前页的显示状态。
扫描二维码关注公众号,回复:
6008679 查看本文章