1、standard :
系统的默认模式,一次跳转即会生成一个新的实例。假设有一个activity命名为A1,执行语句:
后A1将跳转到另外一个A1,也就是现在的栈里面有 A1的两个实例。按返回键后你会发现仍然是在A1(第一个)里面。
2、singleTop:
singleTop 跟standard 模式比较类似。唯一的区别就是,当跳转的对象是位于栈顶的activity(应该可以理解为用户眼前所看到的activity)时,程序将不会生成一个新的activity实例,而是直接跳到现存于栈顶的那个activity实例。拿上面的例子来说,当A1 为 singleTop 模式时,执行跳转后栈里面依旧只有一个实例,如果现在按返回键程序将直接退出。
3、singleTask:
singleTask模式和后面的singleInstance模式都是只创建一个实例的。在这种模式下,无论跳转的对象是不是位于栈顶的activity,程序都不会生成一个新的实例(当然前提是栈里面已经有这个实例)。这种模式相当有用,在以后的多activity开发中,经常会因为跳转的关系导致同个页面生成多个实例,这个在用户体验上始终有点不好,而如果你将对应的activity声明为 singleTask 模式,这种问题将不复存在。
4、singleInstance:
设置为 singleInstance 模式的 activity 将在一个
新task(task可以理解为进程),独占一个task的activity与其说是activity,倒不如说是一个应用,这个应用与其他activity是独立的,它有自己的上下文activity。如果A为singleInstance,B、C为默认模式,依次A-B-C-A,按返回键会跳到B,BC在一个栈,而B位于栈顶
注: singleTask、singleInstance
一
旦
入
栈,
都
为
于
栈底
。
这点
可以
通过
按
back
键
得
到
验证