Android应用程序框架思路整理

一.一般Android应用程序架构(Book,购彩,Market)。

 

普通的应用程序由于只需要用到Android的联网与显示的功能,所以应用程序大体上是呈现为UI(Activities)与网络(Network)等其他模块进行绑定,数据交互的应用程序。

优点: (1)此种是一种通用的类J2ME的应用开发模式,被开发者所熟悉,可以很快上手。

(2)应用比较灵活,小型。

(3)可以满足大部分基于网络数据获取的应用程序。

缺点: (1)不能监控到系统广播服务

(2)不能提供Open API供其他应用程序进行交互

(3)所有模块(如网络等)的生命周期依赖于其所属的Activity的生命周期。

 

二.Android提供的四大应用程序组件

    接下来介绍一下Android提供的四个通用的应用程序组件以及其职责。

 

Activity:

(1)    应用程序的入口

(2)    界面显示,接收事件(如按键),控制显示跳转。

BroadcastReceiver:

(1)    用于注册和接收系统广播的事件

(2)    可接收自定义的广播事件。

ContentProvider:

(1)    提供数据库查询接口

(2)    可对外(其他应用程序)公开数据查询服务。

Service:

(1)    是一个独立的进程,可一直在后台运行。

(2)    可以与其他组件(如Acitivity,Service,ContentProvider)通过远程连接绑定(bind)进行交互。

(3)    可对外(其他应用程序)提供服务交互接口。

(4)    生命周期不依赖于其他组件的存在与否。

 

 

 

三.Service与Acitivity进行交互

 

    Service与其他组件进行通讯是通过AIDL远程接口进行绑定之后进行通信,分别在不同的组件内部创建不同的接口的实现类,通过服务连接器进行交互(ServiceConnection)此种方式可用于不同进程间进行交互,相对比较麻烦一些。

三.Android手机心脏适用的应用程序框架思路

 

由上图可看出,心脏应用程序框架主要分为三层:UI层(Activities层),调度层(Dispatch层)和应用服务层(Services层)。(比较类似于MVC的设计模式)

1.相对于一般框架的区别

(1)引入了Android提供的其他两大组件:服务(Service)和广播接收器(Receiver),用于在后台一直运行一些监控程序(类似于symbian心脏中的WatchEngine.exe)和接收系统事件。

(2)提供了对外部应用程序访问的接口,有助于手机心脏将来为其他应用程序提供平台与服务。

2.三层结构的职责归属与交互方式

层次

组成

职责

与其他层次交互模式

UI层

Activities,Views

负责应用程序UI显示

负责进行跳转

与调度层进行交互

负责控制调度层对服务进行管理

只能与调度层进行交互,不可见服务层。

调度层

由服务管理模块,服务绑定模块,

消息转发模块,

异常通知模块组成

负责与后台服务的绑定与通信

负责处理UI层的请求

负责管理服务层相关服务

负责管理应用程序的异常输出。

与UI层通过本地接口进行交互。

与应用服务层通过远程接口AIDL进行通信。

应用服务层

由Service,Receiver,ContentProvider组成

负责与系统进行通信。

负责监控系统行为并处理。

负责与调度层进行消息通信。

与调度层通过远程接口AIDL进行通信,返回计算结果/事件等。

3.优点与缺点

优点: (1)充分利用Android平台提供的组件达到使用需求(如监控系统事件,保持服务一直运行等),更本地化。

       (2)可以应用系统性比较强的应用程序。

缺点: (1)AIDL进行交互比较繁琐。

你可能感兴趣的:(设计模式,android,框架,UI,service,远程连接)