Android activity四种启动模式总结
android activity四种启动模式总结
android启动模式:? ? ? ? launchmode在多个activity跳转的过程中扮演着非常重要的作用,它可以决定是否生成新的activity实例,是否重用已存在的activity实例,是否和其他的activity实例公用一个task(任务栈)。
? ? ? ? task(任务栈)的概念:task是一个具有栈结构的对象,一个task可以管理多个activity实例,启动一个应用,也就创建一个与之对应的task。task里面的activity是按照先进后出的形式保存的。比如:你打开一个页面,在页面中打开另一个页面,另一个页面退出后,返回的是第一个打开的页面。这就是任务栈的简单原理。
????? ? 栈顶的概念:只要是页面刚打开,不管他是什么模式的,它都是栈顶页面。
????? ? 栈低的概念:首先打开的页面位于最底下,然后后面打开的页面依次往上堆。只有最底下的页面关闭,程序才算完成关闭。
启动模式的概念及理解:
? ? ? ? 1、standard ?(标准启动模式):是默认的启动模式,不用为其配置android:launchmode属性即可。在这种模式下启动的activity可以被多次实例化,即在同一个task中可以存在多个activity的实例。每次启动standard模式的activity时,都创建activity实例并放入task。
????? ? 比如:activity a的启动模式为standard,并且a已经启动,在a中再次启动activity a,即调用startactivity(new intent(this, a.class)),会在a的上面再次启动一个a的实例,即当前的task中状态为a-->a。
????? ? 2、singletop(栈顶复用模式):需要为其配置android:launchmode = "singletop"。如果一个以singletop模式启动的activity的实例已经存在于task的栈顶,那么再次启动这个activity时,不会创建新的实例,而是重用位于栈顶的那个实例,并且会调用该实例的innewintent()方法将intent对象传递到这个实例中。
????????比如:如果a的启动模式为singletop,并且a的一个实例已经存在于栈顶中,那么再调用startactivity(new intent(this, a.class))启动a时,不会再次创建a的实例,而是重用原来的实例,并且调用原来实例的onnewintent()方法。这时任务栈中还是只有一个a的实例。 ?
????? ? 注意:如果以singletop模式启动的acitivity的一个实例已经存在与task中,但是不在栈顶,那么它的行为和standard模式相同,也会创建多个实例。
????????
????? ? 3、singletask(栈内复用模式):需要为其配置android:launchmode="singletask"。如果要启动的activity(singletask模式)在task(任务栈)中存在该实例,则不需要创建,只需要把次activity放入栈顶,并把该activity以上的activity实例都移出栈里面;如果不存在该实例就创建该实例放在栈顶。也就是说:一个栈里面只能有一个singletask模式的activity。
?????????比如:(1)singletask模式的activity已经存在栈顶,那么跳转到自己的页面,它是不会创建自己的activity实例对象的,这个和singletop是一样的。?但如果singletask模式的activity已经不在栈顶,那么跳转到自己的页面,它是不会创建自己的activity实例的,而是会直接跳转到自己的实例activity,并且把压在该模式之上的所有activity实例都移除栈,但是该模式底下的activity实例它是没有办法移除的。
????????????????? ? (2)如果singletask模式的activity都还没有创建,那么它会创建它的activity实例对象,并把自己放在栈顶,这个和所有的activity实例对象都是一样的。
????????? ?注意:一般app主页面都是用singletask模式来设计,因为用户点击多次页面的相互跳转后,再点击回到主页,再次点击退出,这时他的实际需求就是要退出程序,而不是一次一次关闭刚才跳转过的页面,最后才退出。
????? ? 4、singleinstance(全局唯一模式):需要配置android:launchmode="singleinstance"。该模式下,无论是从哪个任务栈中启动activity,只会创建一个目标的activity实例,并且使用一个全新的task栈来加载该activity实例。 ?可以看出singleinstance模式比singletask模式更加霸道,打开一个singletask模式的activity,它如果已经存在,它会把在它之上的该task中的所有activity实例移除。而打开singleinstance模式的activity,不管它存不存在,它都会新建一个task,把自己放在里面,也就是说刚打开的singleinstance的activity在自己新建的task中只有自己一个实例对象。
该模式具备singletask模式的所有特性外,与它的区别就是,这种模式下的activity会单独占用一个task栈,具有全局唯一性,即整个中就这么一个实例,由于栈内复用的特性,后续的请求均不会创建新的activity实例,除非这个特殊的任务栈被销毁了。以singleinstance模式启动的activity在整个系统中是单例的,如果在启动这样的activiyt时,已经存在了一个实例,那么会把它所在的任务调度到前台,重用这个实例。?
????? ? singleinstance模式一般用于资源的共享。比如使用qq打开软件a和软件b。发现退出qq程序后,原来打开的程序并没有被关闭。
????? ? 我们可以在androidmanifest.xml配置的android:launchmode属性为以上四种之一即可。如图所示:
举例如下:
注意:那个activity启动另一个activity,那么被启动的activity就会在启动的activity所在的栈.
例如:?
1.activity a 要启动activity b,那么activity b就会在activity所在的栈中,并且,activity b是在activity a的上面.
现在有两个栈?
栈a:有a,b,c 三个标准启动模式的activity?
栈b:有d,e 两个singletask启动模式的activity
这个使用,activity c要启动activity e,那么启动之后,栈a中的元素顺序就是:activity a,activity b,activity c,activity d,activity e;
这个时候,点击物理返回键返回后,显示的activity 是activity d
如果activity c要启动的是activity d,启动后,栈a的元素顺序就是:activity a,activity b,activity c,activity d.?
这个时候,点击物理返回按键返回后,显示的就是activity c;
上一篇: 瘦脸穴位大解秘!