launchMode在多个Activity跳转的过程中扮演着重要的角色,它可以决定是否生成新的Activity实例,是否重用已存在的Activity实例,是否和其他Activity实例公用一个task里。这里简单介绍一下task的概念,task是一个具有栈结构的对象,一个task可以管理多个Activity,启动一个应用,也就创建一个与之对应的task。
Activity一共有以下四种launchMode:
1.standard
2.singleTop
3.singleTask
4.singleInstance
1、standard:
每次跳转系统都会在task中生成一个新的Activity实例,并且放于栈结构顶部,只有按返回键时我们才能看见以前生成的实例。
Standard启动模式,不管是否存在已有的实例,都会有新的实例产生。
如:任务栈为A、B,要启动B任务,那么任务栈只能是A-B-B形式…
使用方法:
<activity android:name=".MainActivity"
android:launchMode="standard"/>
2、singleTop
SingleTop方式启动时,系统会先在栈结构中寻找一个Activity实例放于栈顶,如果有则不再产生新的,而是直接使用。Activity实例存放于栈顶,重复利用,不再产生新的实例。
如果当前要创建的Activity就在任务栈的顶端,那么不会创建新的Activity,仅仅调用Activity的onNewIntent,如果不在栈顶(或者栈中没有该Activity),那么还是会创建新的Activity.
如:任务栈为A、B,要启动B任务,那么任务栈只能是A-B形式…
使用方法:
<activity android:name=".MainActivity"
android:launchMode="singleTop"/>
3、singleTask
在图中的下半部分是SecondActivity跳转到FirstActivity后的栈结构变化的结果,其中,SecondActivity消失了,在这个跳转过程中系统发现有存在的FirstActivity实例,于是不再生成新的实例,而是将FirstActivity之上的Activity实例统统出栈,将FirstActivity变为栈顶对象。
singleTask启动模式,如果发现有对应的Activity实例,则使此Activity实例之上的其他Activity实例统统出栈,使此Activity实例成为栈顶对象,显示到幕前。
如:任务栈为A、B、C,要启动B任务,那么任务栈只能是A-B形式…
使用方法:
<activity android:name=".MainActivity"
android:launchMode="singleTask"/>
4.singleInstance
singleInstance启动模式比较特殊,会启用一个新的栈结构,将Acitvity放置于这个新的栈结构中,并保证不再有其他Activity实例进入。
我们看到从FirstActivity跳转到SecondActivity时,重新启用了一个新的栈结构,来放置SecondActivity实例,然后按下后退键,再次回到原始栈结构;图中下半部分显示的在SecondActivity中再次跳转到FirstActivity,这个时候系统会在原始栈结构中生成一个FirstActivity实例,然后回退两次,注意,并没有退出,而是回到SecondActivity,为什么呢?是因为从SecondActivity跳转到FirstActivity的时候,我们的起点变成了SecondActivity实例所在的栈结构,这样一来,我们需要“回归”到这个栈结构。
使用方法:
<activity android:name=".MainActivity"
android:launchMode="singleInstance"/>
总结:
standard 每次都会新建,每个Task都可以有,且每个Task都可以有多个实例(每个Task都可以有,且可以有多个)
singleTop 当前实例如果在栈顶,就不新建实例,调用其OnNewIntent。 如不在栈顶,则新建实例 (每个Task都可以有,且可以有多个,在栈顶时可复用)
singleTask 新建一个Task,如果已经有其他的Task并且包含该实例,那就直接调用那个Task的实例。(只有一个Task中会有)
singleInstance 新建一个Task,且在该Task中只有它的唯一一个实例。 (只有一个Task会有,且该Task中只有它)
The last,送上standard和singleTask详解图,多层理解多重进步。
1、standard
2、singleTask
Good luck!
Write by Jimmy.li