Chinaunix首页 | 论坛 | 博客
  • 博客访问: 158960
  • 博文数量: 47
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 405
  • 用 户 组: 普通用户
  • 注册时间: 2014-11-23 14:38
文章分类

全部博文(47)

文章存档

2017年(7)

2016年(4)

2015年(19)

2014年(17)

我的朋友

分类: Android平台

2016-09-27 10:01:25

关于中的组件和应用,之前涉及,大都是静态的概念。而当一个应用运行起来,就难免会需要关心进程、线程这样的概念。在Android中,组件的动态运行,有一个最与众不同的概念,就是Task,翻译成任务,应该还是比较顺理成章的。  Task的介入,最主要的作用,是将组件之间的连接,从进程概念的细节中剥离出来,可以以一种不同模型的东西进行配置,在很多时候,能够简化上层开发人员的理解难度,帮助大家更好的进行开发和配置


任务      

在 SDK中关于Task(guide/topics/fundamentals.html#acttask),有一个很好的比方,说,Task就相当于应用(application)的概念。在开发人员眼中,开发一个Android程序,是做一个个独门独户的组件,但对于一般用户而言,它们感知到的,只是一个运行起来的整体应用,这个整体背后,就是Task。  Task,简单的说,就是一组以栈的模式聚集在一起的Activity组件集合。它们有潜在的前后驱关联,新加入的Activity组件,位于栈顶,并仅有在栈顶的Activity,才会有机会与用户进行交互。而当栈顶的 Activity完成使命退出的时候,Task会将其退栈,并让下一个将跑到栈顶的Activity来于用户面对面,直至栈中再无更多 Activity,Task结束


事件    Task栈   

点开Email应用,进入收件箱(Activity A)    A  

选中一封邮件,点击查看详情(Activity B)    AB  

点击回复,开始写新邮件(Activity C)    ABC  

写了几行字,点击选择联系人,进入选择联系人界面(Activity D)    ABCD  

选择好了联系人,继续写邮件    ABC  

写好邮件,发送完成,回到原始邮件    AB  

点击返回,回到收件箱    A  

退出Email程序    null


 如上表所示,是一个实例。从用户从进入邮箱开始,到回复完成,退出应用整个过程的Task栈变化。这是一个标准的栈模式,对于大部分的状况,这样的Task 模型,足以应付,但是,涉及到实际的性能、开销等问题,就会变得残酷许多。比如,启动一个浏览器,在Android中是一个比较沉重的过程,它需要做很多初始化的工作,并且会有不小的内存开销。但与此同时,用浏览器打开一些内容,又是一般应用都会有的一个需求。设想一下,如果同时有十个运行着的应用(就会对应着是多个Task),都需要启动浏览器,这将是一个多么残酷的场面,十个Task栈都堆积着很雷同的浏览器Activity,是多么华丽的一种浪费啊。于是你会有这样一种设想,浏览器Activity,可不可以作为一个单独的Task而存在,不管是来自那个Task的请求,浏览器的Task,都不会归并过去。这样,虽然浏览器Activity本身需要维系的状态更多了,但整体的开销将大大的减少,这种舍小家为大家的行为,还是很值得歌颂的


LaunchMode(启动模式)
  1、标准模式
    1)从task中启动Activity时,该Activity的新实例总是在当前
      task中创建
    2)每次启动Activity,都会创建该Activity类的新实例
    3)一个task中可以存在同一Activity的多个实例
    4)一个Activity的多个实例可以出现在多个task栈中
  2、singleTop
    1)如果启动模式设置为singleTop的Activity实例未处于栈顶,
      则其表现与启动模式设置为standard的Activity的表现一致
    2)如果启动模式设置为singleTop的Activity的实例位于任务栈的栈顶
      则,不会创建该Activity的新实例。只是调用位于栈顶的该Activity
      实例的onNewIntent方法,将新的intent传递给该实例。  
  3、singleTask
    1)设置为singleTask的Activity,具有全局唯一性,在Android系统中
      只能创建该Activity的一个实例。
    2)如果启动s设置为singleTask的Activity时,已经存在该Activity的
      实例,则将该实例之上的所有Activity实例释放,将该实例重新带回到
      栈顶,并调用器onNewIntent方法,将新的intent传递给该实例
    3)在创建设置为singleTask模式的Activity的实例时,如果当前task的
      taskAffinity与该Activity的taskAffinity一致,则直接在当前task中
      创建;如果当前task的taskAffinity值与该Activity的taskAffinity不一致
      则在新的任务中创建该Activity的实例。
  4、singleInstance
    1)当创建设置为singleInstance模式的Activity时,总是在新的任务中创建
    2)设置为SingleInstance模式的Activity,具有全局唯一性。在Android系统
      中只能存在该Activity的一个实例
    3)设置为singleInstance模式的Activity,总是单独在一个task中存在
      也就是说在该Activity所在的task栈中不可能存在其他的activity

阅读(1383) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~