● Android 任务栈简介

一个Android应用程序功能通常会被拆分成多喝Activity,而各个Activity之间通过Intent进行连接,而Android系统,通过栈结构来保存整个App的Activity,栈低的元素是整个任务栈的发起者。一个合理的任务调度栈不仅是性能的保证,更是提供性能的基础。

当一个App启动时,如果当前环境中不存在App的任务栈,那么系统就会创建一个任务栈。此后,这个App所启动的Activity都将在这个任务栈中被管理,这个栈也被称为一个Task,即表示若干个Activity的集合,他们组合在一起形成一个Task。另外,需要特别注意的是,一个Task中的Activity可以来自不同的App,同一个App的Activity也可能不在一个Task中。

关于栈结构,相信大家都不会陌生——后进先出(Last In First Out)的线性表。根据Activity当前栈结构中的位置,来决定该Activity的状态。先来看看正常情况下的Android任务栈。当一个Activity启动了另一个Activity的时候,新启动的Activity就会置于任务栈的顶部端,并处于该活动,而启动它的Activity虽然功成身退,但依然保留在任务栈中,处于停止状态,当用户按下返回键或者调用finish()方法时,系统会移除顶部Activity,让后面的Activity恢复活动状态。当然世界不可能一直那么“和谐”,可以给Activity设置一些“特权”,来打破这种“和谐”的模式。这种特权,就是通过AndroidMainifest文件中的属性android:launchMode来设置或者是通过Intent的flag来设置

● AndroidMainifest启动模式

下面我们来看看这些“特权”都有哪些能力。Android开发者在AndroidMainifest文件中一共设计了四种启动模式,如下所示。

▶ standard

▶ singleTop

▶ singleTask

▶ singleInstance

这四种启动模式都具有不同的功能,下面我们一一学习一下。

● standard

默认的启动模式,如果不指定Activity的启动模式,则使用这种方式启动Activity。这种启动模式每次都会创建新的实例,每次点击standard模式创建Activity后,都会创建新的MainActivity覆盖在原Activity上,结构如图(1)所示。

                                                                               图(1)standard启动模式

● singleTop

如果指定启动Activity为singleTop模式,那么在启动时,系统会判断当前栈顶Activity是不是要启动的Activity,如果是则不创建新的的Activity而直接引用这个Activity;如果不是则创建新的Activity。这种启动模式通常用于接收到消息后显示的界面,例如QQ接收到消息后弹出的Activity,如果一次来十条消息,总不能一次弹出十个Activity,这种启动模式的任务栈结构如图(2)所示。

                                                                             图(2)singleTop启动模式

这种启动模式虽然不会创建新的实例,但是系统仍然会在Activity启动时调用onNewIntent()方法。举个例子来说,如果当前任务中有A、B、C三个Activity,而且C的启动模式是singleTop的,那么这时候如果再次启动C,那么系统就不会创建新的C的实例,而是会调用C的onNewIntent()方法,当前任务栈中依然是A、B、C三个Activity。

● singleTask

singliTask模式与singleTop模式类似,只不过singleTop是坚持栈顶元素是否是需要启动的Activity,而singleTask是检测整个Activity栈中是否存在需要启动的Activity。如果存在,则将该Activity置于栈顶,并将该Activity以上的Activity都销毁。不过这里是指在同一个App中启动这个singleTask的Activity,如果是其他程序以singleTask模式来启动这个Activity,那么它将创建一个新的任务栈。不过这里有一点需要注意的是,如果启动的模式为singleTask的Activity已经在后台一个任务栈中了,那么启动后,后台的这个任务栈将一起被切换到前台,借助官网上的一张图可以更好的理解这一过程,如图(3)所示。

                                                                图(3)singleTask启动模式特例

当Activity2启动ActivtyY(启动模式为singleTask)时,它所在的Task会被切换到前台,且按返回键的返回时,也会先返回ActivityY所在的Task的Activity,这一点比较难理解,希望大家能通过图(3)认真理解这一过程。

可以发现,使用这个模式创建的Activity不是在新的任务栈中被打开,就是将已打开的Activity切换到前台,所以这种模式通常可以用来退出整个应用:将住Activity设为singleTask模式,然后在要退出的Activity转到主Activity,从而将主Activity之上的Activity都清除,然后重写主Activity的onNewIntent()方法,在方法中加上一句finish(),最后一个Activity结束掉。

● singleInstance

singleInstance这种模式和使用阅览器工资类似。在多个系统访问阅览器时,如果当前阅览器没有打开,则打开阅览器,否则会在当前打开的阅览器中访问。申明为singleInstance的Activity会出现在一个新的任务栈中,而且这个任务栈只会存在一个Activity。举个例子来说,如果应用A的任务栈中创建了MainActivity实例,且启动模式为singleInstance,如果应用B也激活MainActivity,这不需要创建,两个应用共享该Activity实例。这种启动模式常用与程序分离的界面,如在SerupWizard中调用紧急呼叫,就是使用的这种启动模式。

关于singleTop和singleInstance这两种启动模式还有一点需要特殊说明:如果在一个singleTop或者singleInstance的ActiivtyA中通过setartActivityForResult()方法来启动另一个ActivityB,那么系统将直接返回Activity.RESULT_CANCELED而不会再去等待返回。这是由于系统在Framework成做了对这两种模式的限制,因为Android开发者认为,不用的Task之间,默认是不能传递数据的,如果一定要传递,那就只能通过Intent来绑定数据。

更多相关文章

  1. No.11 使用firewall配置的防火墙策略的生效模式
  2. Nginx系列教程(六)| 手把手教你搭建 LNMP 架构并部署天空网络电影
  3. 关于android:sharedUserId="android.uid.system"这个系统级权限
  4. 从零开始--系统深入学习android(实践-让我们开始写代码-Android框
  5. Android中的代理模式
  6. 关于 Android(安卓)中 Support 支持包(1)
  7. Mac系统搭建STF环境
  8. Android(安卓)-- 系统网络时间更新NetworkTimeUpdateService服务
  9. Android基础教程(九)之自定义下拉菜单模式----Spinner与setDropD

随机推荐

  1. 闲聊Kubernetes Pod垂直自动伸缩(VPA)
  2. php处理post传递json格式参数请求
  3. VUE---路由菜单Icon自定义的实现
  4. 基于Cocos SDKHub接入华为HMS Game服务—
  5. Kubernetes客户端和管理界面大集合
  6. 中小企业需要的报表工具一般具备什么功能
  7. Kubernetes集群管理容器实践(概念篇)
  8. php函数知识
  9. 语音也能做持续集成和持续部署?看 Jenkins
  10. 啤酒与***:培养***格调的6个建议