Android App 项目架构Android知识Android技术知识

Android项目架构1 - TODO-MVP(译)

2017-02-07  本文已影响133人  热血沸腾

Github官方地址      todo‑mvp 深入浅出学习 

概要

该例是其他衍生例子的基础。该例不使用Android framework而简单实现了 Model-View-Presenter 模式。本地和远程数据源仓库是通过手工依赖而注入的。异步任务通过操作回调

架构示意图

注意:

在MVP的上下文中,叫做"view"的应该重新解读:

1. "android.view.View"包下的类会被解读为View

2. 在MVP中一个从Presenter接受命令的View被简单的叫做“View”

Fragments

使用Fragments有两个原因:

1. Activity与Fragment的友好分离非常适合实现MVP:Activity对于创建、联系View和Presenter是总的控制器

2.平板的多View多屏幕利用的Fragment框架的优势来布局的

关键概念

app中有四个功能

1. Tasks

2. TaskDetail

3. AddEditTask

4. Statistics

每个功能都有:

1.  View和Presenter之间具有协议(接口实现)

2. 一个负责创建Fragment和Presenter的Activity

3. 实现了View接口的Fragment

4.实现了Presenter接口的Presenter

一般来讲,业务逻辑是存在于Presenter中的,并且通过Android UI 来操作一些动作。View中几乎没有逻辑: 它接受Presenter的命令而使得UI发生变化,并且监听用户动作回馈给Presenter。View与Presenter之间的的协议通常是通过interface来定义的。

依赖

Android 原生库(com.android.support.*)

Android 测试库(Espresso, AndroidJUnitRunner…)

Mockito  测试库

Guava (null checking)  基于1.6的扩展类工具集合

特征

复杂性-可理解性

使用第三方框架/依赖/工具? 没有

概念复杂性

低,因为它是Android上纯净的MVP实现

测试性

单元测试

高,Presenter 和 数据源都是独立单元

UI测试

高,允许fake数据注入到fake模型中  (fake 有点像模拟,伪造的意思)

代码量

相比于传统的工程

与没有架构的传统项目比,本例引入了额外的类、接口、Presenter、仓库等。因此,MVP架构中代码的行数和类数量会更多些。

代码量示意图

可维护性

易于修改或添加功能

学习成本

低。功能很容易找到,责任明确。开发人员不需要熟悉任何外部依赖项来处理项目。

上一篇下一篇

猜你喜欢

热点阅读