摘要:模式所有都在同一个栈中。启动时,如果该实例已经存在于栈顶,则复用该实例否则,生成一个新的实例。二重要的启动标识通过代码实现启动模式。联合使用清空当前栈。如果在发现登陆过期,需要重新登录,并且登陆后需要重新进入主页面相当于全部重新启动一遍。
一、Activity四种启动模式
这4种启动模式都是通过在manifest中注册实现的。
standard模式:所有activity都在同一个task栈中。每次启动activity,都会生成一个新的activity实例。
singleTop模式:所有activity都在同一个task栈中。启动activity时,如果该activity实例已经存在于栈顶,则复用该activity实例;否则,生成一个新的activity实例。
singleTask模式:所有activity都在同一个task栈中。启动activity时,如果该activity实例已经存在于栈中,则复用该activity实例,同时弹出该activity上面的所有实例;否则,生成一个新的activity实例。
singleInstance模式:会在一个新的task栈中启动该activity实例,且这个栈中有且只能有这一个activity实例。
通过代码实现启动模式。
Intent intent = new Intent(); intent.setClass(context, DemoActivity.class); intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK); context.startActivity(intent);
Intent.FLAG_ACTIVITY_NEW_TASK:在一个新的task栈中启动activity,但是并不是一定会在一个新的task栈中启动activity。如果系统为该activity找到一个极具亲和力(taskAffinity的值相等)的task栈,就不会在新的task栈中启动Activity。
Intent.FLAG_ACTIVITY_CLEAR_TOP:清空当前task栈中,该activity之上的所有activity实例,当前activity是否会重新onCreate,取决于是否与Intent.FLAG_ACTIVITY_SINGLE_TOP标记连用。
Intent.FLAG_ACTIVITY_SINGLE_TOP:只用Intent.FLAG_ACTIVITY_CLEAR_TOP当前Activity会重新onCreate,Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP组合使用,当前Activity不会重新onCreate。
Intent.FLAG_ACTIVITY_CLEAR_TASK:清空当前task栈中,所有activity实例。
Intent.FLAG_ACTIVITY_CLEAR_TASK+Intent.FLAG_ACTIVITY_NEW_TASK联合使用:清空当前task栈。然后在一个新的task栈中启动activity,但是并不是一定会在一个新的task栈中启动activity。如果系统为该activity找到一个极具亲和力(taskAffinity的值相等)的task栈,就不会在新的task栈中启动Activity。
Intent.FLAG_ACTIVITY_CLEAR_TOP+Intent.FLAG_ACTIVITY_NEW_TASK联合使用:清空当前task栈中,该activity之上的所有activity实例。然后在一个新的task栈中启动activity,但是并不是一定会在一个新的task栈中启动activity。如果系统为该activity找到一个极具亲和力(taskAffinity的值相等)的task栈,就不会在新的task栈中启动Activity。
假如有3个task栈,task1中包含activity1,task2中包含activity2,task3中包含activity3和activity4,假如task1、task2、task3的位置关系是,task3位于顶部。
只有最上层task栈中的activity有启动别的activity的权限:上述例子中,activity3和activity4可以启动别的activity,activity1和activity2无法启动别的activity。
顶层activity所在栈一定位于顶部:上述例子中,假如activity3启动了activity1,那么task1将被提到顶部。activity1可以启动别的activity,activity2、activity3和activity4无法启动别的activity。
taskAffinity用于标记当前activity应该属于哪个task栈:如果activity没有指定taskAffinity的值,那么就等于application的taskAffinity的值,如果application也没有指定,那么taskAffinity的值就等于包名。
默认情况下,Intent.FLAG_ACTIVITY_NEW_TASK不会在新的task栈中启动activity:因为能找到一个极具亲和力的task栈,默认情况下,activity的taskAffinity值都等于包名。
activity重新宿主:如果application1的activity1与application2的activity2的taskAffinity值相等,且application1的activity1的allowTaskReparenting设置为true。启动activity1后退到后台,再启动activity2时,activity1会重新宿主,也就是说会先看到activity1。
LoginActivity->HomeActivity->ActivityA->ActivityB
假设从登陆页面(登录后页面finish),跳转到主页面,再跳转到ActivityA,再跳转到ActivityB。如果在ActivityB发现登陆过期,需要重新登录,并且登陆后需要重新进入主页面(相当于全部重新启动一遍)。
方案一:可以把HomeActivity设置为singleTask。
方案二:可以使用Intent.FLAG_ACTIVITY_CLEAR_TASK。
方案三:可以使用Intent.FLAG_ACTIVITY_CLEAR_TOP。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/69039.html
摘要:原文地址游客前言金三银四,很多同学心里大概都准备着年后找工作或者跳槽。最近有很多同学都在交流群里求大厂面试题。 最近整理了一波面试题,包括安卓JAVA方面的,目前大厂还是以安卓源码,算法,以及数据结构为主,有一些中小型公司也会问到混合开发的知识,至于我为什么倾向于混合开发,我的一句话就是走上编程之路,将来你要学不仅仅是这些,丰富自己方能与世接轨,做好全栈的装备。 原文地址:游客kutd...
摘要:内存泄漏当应用内部不再需要某个实例后,但是这个对象却仍然被引用,这个情况就叫做内存泄露。安卓虚拟机为每一个应用分配一定的内存空间,当内存泄露到达一定的程度就会造成内存溢出。点击登录跳转页面中所有操作都与用户密切相关,是 Android: 今日头条屏幕适配的原理? 1:首先计算出 density,计算公式:当前设备屏幕总宽度(单位为像素)/ 设计图总宽度(单位为 dp) = densit...
阅读 2305·2021-09-28 09:45
阅读 3596·2021-09-24 09:48
阅读 2256·2021-09-22 15:49
阅读 3093·2021-09-08 16:10
阅读 1586·2019-08-30 15:54
阅读 2317·2019-08-30 15:53
阅读 3012·2019-08-29 18:42
阅读 2864·2019-08-29 16:19