Activity的架构设计

一、概述

        Activity是Android应用程序用户界面的基本组件,它与Service、ContentProvider、Broadcast Receiver被称为Android应用程序的四大核心组件。从应用程序结构层次上来说,每个Android应用是Application类的一个实例,每个Android应用可以包含多个Activity实例。一个Activity实例代表应用程序窗口(Window)组件,它本身并不提供用户界面,它是所有UI控件依附的容器。Activity可以获得焦点、接收用户事件,并把事件分发给内部的UI控件处理来完成整个交互过程。

         Android应用程序通常都是由很多Activity组成,一个应用从开始运行到运行结束构成了Android应用程序的生命周期。在Android系统框架中Application实际上代表了应用程序的上下文环境,Activity才是重要的表现者,一个完整的应用程序的生命周期通常由许多Acitivity的生命周期构成。

         Android应用程序在运行时,系统都会为它分配一个独立的虚拟机进程,每个应用程序都运行在独立的进程空间。Android系统是基于Linux操作系统的,所以Android的进程概念与Linux操作系统的进程概念相同。Android应用程序一般由Activity、Service、ContentProvider、Broadcast Receiver 等组件构成,这些组件的运行过程都需要依附于Linux 进程。

         对于进程来说,如果要让它常驻内存为其他组件提供服务,必须要建立一个闭合的消息循环(死循环)。对于Android应用程序来说,应用程序进程启动之后也开启了一个闭合消息循环,然后把组件依附在进程之上。
理解Android中Activity的架构设计,以及Android应用把Activity组件依附到linux进程的过程,可以从以下三个方面入手:

二、 应用程序进程空间

         Dalvik是Google为Android系统定制的虚拟机,Android系统支持同时运行多个虚拟机实例,每个Android应用程序都在自己的进程中运行,它们都拥有一个独立的Dalvik虚拟机实例。

         每个应用程序进程都有各自的进程名字,可以在Android工程的AndroidManifest.xml文件中,修改 <application />节点的android:process属性设置应用程序进程的名称,通常情况都不需要设置这个属性,因为每个Android应用都会有一个不同于其他应用的包名, Android系统会使用应用程序的包名作为应用程序进程的名字。

         一个Android应用通常由多个Activity组成,其中有一个“主Activity”为应用启动时第一个显示的Activity。Activity Manager Service 在应用程序的第一个组件需要运行时将会为应用程序建立一个进程,而这个进程的名字就是由android:process=”string”指定,默认情况是应用程序的包名,建立进程之后所有组件都将运行在该进程中。在加载第一个Actvitiy 时,如果应用程序还没有创建Application对象,应用程序会首先建立一个Application 对象,并初始化应用程序上下文。

         当应用程序被安装到设备上时,Android系统会为每个应用程序分配一个Linux用户ID,并设置相应的资源访问权限,这样应用程序之间就不能相互访问各自拥有的数据和资源。在Linux系统中,一个用户ID对应一个特定的用户,在Android系统中,一个用户ID对应一个特定应用程序。只要应用程序没有被卸载,Android系统为应用程序分配的Linux用户 ID会保持不变。 

         默认情况下,每个应用程序运行在它自己的Linux进程中。当应用程序启动时,Android系统的虚拟机孵化器会为这个应用程序启动一个新虚拟机进程,因此不同的应用程序是运行在相互隔离的虚拟机进程中。
如下图所示:

QQ截图20120518101956.png

图1  应用程序运行在独立的进程空间


         如果需要共享几个应用程序之间的数据和资源,也可以给这些应用程序分配相同的Linux用户ID,这样多个应用程序之间就能相互访问各自所拥有的资源。Android系统把具有相同Linux用户ID的应用程序,运行在同一个进程中共享同一个虚拟机,这样能够更高效地使用系统资源。如果要实现不同的应用程序运行在相同的进程中,通过修改<manifest  />节点的android:sharedUserId属性,给几个不同的应用程序设置相同的 Linux 用户 ID,然后必须在应用程序打包时,使用相同的私钥签署这些应用程序。Android系统中的应用程序Launcher和Contacts就设置了同样的sharedUserId。

QQ截图20120518102011.png

图2  不同应用程序运行在相同进程空间


三、 ActivityThread 运行框架

         在Android系统框架中,android.app.Application类并不是代表应用程序进程,它实际上代表了应用程序的上下文环境,而ActivityThread类才是真正的代表应用程序进程。

         每个应用程序都以ActivityThread.main()为入口,执行Looper类的loop()方法后进入到消息循环。对于Android应用进程来说非常需要像这样闭合的处理框架。ActivitiyThread是应用程序进程空间的重要概念,它建立了应用进程运行的框架,并提供了一个IActivityThread 接口与Activity Manager Service通讯。通过IActivityThread接口Activity Manager Service可以将Activity 的状态变化传递到客户端的Activity对象。

         Actvitiy Manager Service与应用进程的绑定分为两步,第一部分就是Actvitiy Manager Service建立应用程序进程,第二部分是应用程序进程绑定到Actvitiy Manager Service并与Actvitiy Manager Service建立通讯通道。这部分就不再展开讲解了,只需了解应用进程与Actvitiy Manager Service的绑定。

QQ截图20120518102022.png

图3  ActivityThread 运行框架



四、 Activity加载过程

         对于Activity Manager Service来说Activity就是对应的客服端。在编写Android 应用程序时,需要扩展Android 系统框架中的Activity类,在子类中实现Activity类提供的一些与生命周期相关的方法:void onCreate(Bundle savedInstanceState)、void onRestart()、void onStart()、void onResume()、void onPause()、void onStop()、void onDestroy()等。

         在定义Activity的子类并实现了一些与生命周期相关的方法之后,其他的操作都由Android系统后框架完成,这对于Android应用开发者来说都是透明的,也就是应用开发者无需关心Android系统对Activity的调度过程。

         上面的内容已经说到 Android应用程序进程对应的类就是ActivityThread类,Activity的加载和调度的过程都是通过ActivityThread类完成的。

         从ActivityThread源码中可以看出,在应用程序进程中的Activity 都被放置在mActivities 数组中。这些ActivityRecord记录了应用程序进程中所有Activity子类的实例。每个Activity子类实例代表应用程序端与用户交互的Activity。为了方便管理这些Activity,Activity Manager Service内核中也保留了一些对应的Activity,被称为HistoryRecord,它是activity栈的核心组成部分。

         在Android系统框架中Activity 实际上有两个实体。一个在应用进程中与负责与用户交互的Activity,另外一个是在Activity Manager Service中具有管理功能的History Record。应用进程中的Activity 都记录在ActivityThread实例中的mActivity 数组中,而Activity Manager Service中的HistroytRecord 实例放置在mHistroy 栈中。mHistory 栈是Android 管理Activity 的场所,处于栈顶的Activity就是用户看到的当前处于活动状态的Activity。

         Activity 的内核实体是依附在ProcessRecord 的成员变量中,通过ProcessRecord 可以访问到所有属于该Process 的Activity。通过IActivtityThread接口,可以访问到它对应的Activity 的方法。在LaunchActivity 时,Activity Manager Service将对应的HistoryRecord 作为token 传递到客服端与客服端的Activity 建立联系。当Activity Manager Service中的Activity 状态变化时,Activity Manager Service找到客服端的Activity,从而将消息或者动作传递应用程序中对应的Activity 。


QQ截图20120518102031.png

图4  ActivityThread管理acitivity的内部结构图


转载于:https://my.oschina.net/limbusnet/blog/75453

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
宏天BPM X3软件平台是一个易于部署和使用的新一代业务流程管理平台,能够以最快的速度帮助您梳理、设计、执行、监控分析和优化业务流程,从业务和IT相结合的完美视角为用户组建长期而久远的卓越BPM流程管 理架构。通过实施BPM方案让您的企业在运营效率、透明度、控制力和敏捷性方面迅速受益。 BPMX3是基于J2EE开源、轻量级的企业业务开发平台,基于代码重用、组件重用、业务逻辑重用、组装重用,结合快速开发平台中的工具,将开发人员从重复的代码编写中解放出来,把更多的精力集中解决客户的业务逻辑处理上。 BPMX3是支持流程管理、监控、优化、再造的全套IT管理开发平台,并且集单点登录、企业单位门户、业务流程管理、开发、整合、业务分析及重构等多重职能于一身的软件开发工具和企业IT架构平台。 BPMX3是企业管理业务的创新关键,可以帮忙用户更科学、更有效管理企业业务的各个环节,企业通过BPMX3可以明显实现业务的高效运营。同时,由于其架构的开放性,采用业界开放性的技术及流程标准,使其能够成为企业SOA架构的流程基础平台及开发平台,越来越多的企业更偏向采用开源的平台来解决其内部的信息化平台的要求,BPMX3却允许更多的平台系统接入及自身扩展更多的功能,以满足更多的企业不同的个性化的需求,以达到最大满足最终的客户使用要求。 【图一】工作流引擎中心 1.BPMX3的特点 1.是一个开放式、轻量级的开发平台 2.BPMX3多层系统架构 3.基于模板代码生成 4.丰富的报表展示 5.跨数据库的数据访问支持 6.简易的前端使用 7.参照最新的BPMN2标准设计 8.满足中国特色流程需求 9.在线的可视化流程设计、可视化的流程监控 10.完全独立的流程引擎服务,可与其他系统无缝集成 11.基于流行的JAVA 流程引擎Activiti 5.8扩展 12.灵活的在线流程定义 13.灵活的嵌入式部署、独立部署 14.灵活的在线表单定义及版本管理(支持按内表及外部表及视图生成表单) 15.灵活的第三方表单集成 16.开放式的流程体系 17.灵活的组织结构支持 18.流程的导入与导出 19.子流程支持 20.流程任务逐步回退处理(任务追回及多驳回 ) 21.流程自由跳转 22.流程跳转业务规则设置 23.多级分发任务与任务汇总 24.会签(并行与串行)、补签及投票处理 25.流程版本变更管理 26.流程催办(基于MQ短信及邮件设置) 27.流程任务的工作日设置(用于统计流程任务执行效率) 28.任务监控管理 29.流程委办、转办 2.BPMX3多层架构 系统采用多层的系统架构进行功能开发,有利于代码功能责任分开,同时有利于不同开发人员的分工及合作,也有利于代码的单元测试。系统总体结构如下图所示: 【图二】BPMX3多层架构 •数据访问层Dao: 负责与数据库交互 •业务处理层Service: 负责系统的所有业务逻辑处理 •数据控制层Controller: 负责系统的页面数据准备及跳转处理 •视图层View :负责数据的展示处理 整合的开源技术 1.Spring Core 3.0.4 2.Spring MVC 3.0 3.Spring Security 3.0.5 4.Spring AOP 3.0.4 5.Apache Active MQ 5.5 6.MyBatis 3 7.CKEditor 3.6 8.JQuery 1.8 9.CXF 2.0 10.Alfresco Activiti 5.8 11.Compass + Lucene 12.JasperReport 4.5 13.JavaMail 14.Other: Log4j,Velocity,Sitemesh,Jfreechart,Jforum,Solr 15.Maven 2 3.BPMX3的组件构建方式 BPMX3同时也是基于组件构构建,整个系统的构建如下所示: 【图三】BPMX3组件构建 系统提供在线流程设计器,在线表单设计器,代码生成器,结合BPMX3的基础组件,以实现复杂的流程业务应用。基础组件包括: Spring基础组件库,报表引擎,数据库访问模块,短信模块,后台定时任务调用组件,短信访问组件,搜索引擎组件,JMS消息组件,Activiti工作流组件,Cas统一用户认证组件,Spring安全认证组件。 4.BPMX3总体功能 1.多系统管理 BPMX3支持多个业务系统同时运行及切换处理,根据不同的用户授权允许用户进入不同的系统进行访问,而不同的业务系统的开发可以基于BPMX3平台上开发,也可以由其他开发框架开发再与BPMX3做整合。这种模式非常适合企业把BPMX3作为其内部的首先开发平台,以使后续的新应用系统都整合在一起进行管理及使用。 【图四】多系统管理 2.用户管理 BPMX3提供多种维度的用户人员管理,以支持各种类型的组织机构及人员的统一管理,目前可以支持内部组织、外部组织 、虚拟组织。而且还提供用户的属性自定义,允许对用户进行多种属性的扩展,以支持工作流中的任务节点的人员的复杂查找计算。 3.系统安全管理 系统的安全管理由Spring Security 3提供配置及管理,非常容易与第三方的用户或认证平台进行整合,如与CAS服务器作统一认证,只需要加上新的配置模块即可实现,不影响系统现有的功能模块。大大满足了各种不同系统的安全管理认证的需要。 同时系统可以支持URL访问权限、数据权限、列权限及页面按钮权限的统一配置管理。系统的安全认证机制如下所示: 【图五】系统安全拦截原理 4.动态表单管理 BPMX3提供了基于数据库内部表、外部表、视图等来生成在线的流程表单的功能,其生成是基于模板,模板可由开发人员进行自定义,也可以采用BPMX3提供的默认模板。生成的表单后,系统管理员还可以对表单进行编辑管理以实现企业的业务要求,其中,还允许开发人员在表单上编写编写脚本,以实现更复杂的应用。 表单上支持系统中的大量组件,如角色选择,用户选择,角色选择,在线表单,套红在线Office表单,签章表单等。系统开发人员几乎不用作任何开发,可以设计出任何复杂的表单应用需求。 表单上支持系统中的大量组件,如角色选择,用户选择,角色选择,在线表单,套红在线Office表单,签章表单等。系统开发人员几乎不用作任何开发,可以设计出任何复杂的表单应用需求。 【图六】在线动态表单 5.流程管理 BPMX3提供了基于BPMN2标准的流程管理,包括流程版本变量,流程节点表单设置,表单的权限设置,流程任务通知,催办,代办,转化,并行会签、串行会签、补签,子流程,同步任务,多实例任务,人工任务、消息任务、邮件任务等,任务多级分发与汇总、任务追回、任务层层驳回,任务自由跳转等中国特色的流程需求。能满足企业复杂的流程应用需求。 BPMX3在流程管理上,不但能结合在线设计的复杂表单,还能结合本系统或其他系统其他模块的功能表单一起进行业务审批的工作。这大大方便了业务流程在所有的系统中进行流程开发的工作,简化了以往开发流程业务的代码固死的做法,把程序员或业务员真正从流程业务中解放出来。 【图七】在线流程管理 【图八】在线流程设计 6.报表管理 系统的报表管理是基于模板来进行设置管理的,目前支持FineReport及Jasper Report两种报表引擎,前者是商业报表,其功能非常强大,可以实现多样式数据呈现方式,支持HTML、PDF、EXCEL、Word、TXT、Flash样式呈,能完美解决中国式报表难题,无论数据库内原始数据是以何种样式的表结构存储,无论最终用户要求数据以何种表格样式显示,FineReport报表软件独创的多数据源关联查询、公式动态扩展计算等强大的功能,在无需改变表结构,无需改变用户的要求的基础上,完全按照用户的需求制作出报表模板。 【图九】报表管理 7.系统基础组件 系统的基础组件如用户模块一样,是系统的业务功能的基础,在其他业务模块中被大量使用。 ◦定时任务管理 通过配置以实现某时刻重复执行的系统任务,如配置每月最后一天进行库存清算任务,并且启动库存清算审批流程。 ◦系统日志管理 记录进入系统中的每个用户访问的每个功能 ◦数据源管理 可以设置多种数据源,为在线表单设计及展示提供数据来源 ◦资源管理 管理系统的所有资源,包括URL,业务方法等,提供给安全管理进行极限配置 ◦流水号管理 用于产生业务的一些处理流水单号 ◦数据字典管理 用于管理所有的业务中常用的数据字典的数据 ◦附件管理 管理系统中所有的上传附件。 ◦桌面管理 管理用户的桌面布局及常用的功能展示 ◦邮件、短信模板管理 用于配置系统的发送邮件、短信的模板 ◦工作日历管理 用于配置系统的工作流的待办事项的处理工作时间的计算处理 ◦动态脚本管理 用于为流程任务节点或事件中可被调用的逻辑计算代码 ◦短信收发管理 基于USB短信猫的短信模块或短信网关,以实现收发手机短信功能。 ◦外部邮件管理 支持POP3,IMap协议的邮件服务收发功能,允许用户设置多个外部邮箱。 ◦内部短消息收发管理 在系统中用户之间可以收发短消息,如工作流任务的通知也采用短消息进行实时提醒。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值