Android应用架构 — 从MVC到MVVM

=====

起源与发展

MVC模式最初由Trygve Reenskaug于1979年提出并定义:

  • Model: Model可以是一个独立的对象,也可以是一系列对象的集合体。
  • View: View是Model中一些重要数据在视觉上的体现。
  • Controller: Controller用于连接用户和系统,Controller接收到用户的输入时,会将其转化成合适的事件消息,并将该事件消息传递给一个或多个View。

1979年的MVC

在早期的MVC模式中,因为起初GUI框架羸弱,无法捕获处理用户事件,所以用户的操作事件由Controller捕获并处理,Controller与View之间没有直接联系。 它们之间主要靠用户和Model来连接,用户使用Controller发起操作,Controller操作Model更新数据,Model更新完数据,再反映到View上以展示给用户。因此,你可能找到下图这样的结构:

Wiki上的MVC

再后来,随着技术的发展,View层的能力逐渐强大起来,开始能主动监听并处理一些用户事件了,而Controller则负责协助View处理事件,并且揽下了一部分介于View和Model之间的业务逻辑,在这期间MVC演化出了许多不同的分支,这些分支五花八门各不相同,但是无论怎样改变,仍然保持着Model、View、Controller三个组成部分。

五花八门的MVC

在各种分支中,有一个不得不提到的特殊分支。
随着Web开发的兴起,传统的MVC模式遇到了一个麻烦:View在用户的浏览器中显示,而Model存在于服务器中,Model无法主动通知View更新了。
为此Web开发人员改善了MVC的事件流:当用户作出交互请求时,首先将这个交互事件交给对应的Controller,Controller根据情况完成对Model的操作,Model将操作的结果告诉Controller,再由Controller根据结果组装View返回给浏览器。

这样一来,MVC看起来就很像后来的MVP了:

在Web端用的MVC

角色划分

  • Model: 用来保存程序的数据状态,比如数据存储,网络请求等。
  • View: GUI组件构成,向用户展示Model中的数据。
  • Controller: 连接用户和系统,响应交互,传递数据。

解决的问题

MVC最重要的目的并不是规定各个模块应该如何交互和联系,而是将原有的混乱的应用程序划分出合理的层级,把以往一团混乱的代码,按照展示层和领域层分成两个部分。这种分离使得位于领域层中的领域对象可以不需要对展示层有任何了解,因此可以同时为不同的展示层工作,从而初步的实现了领域层与展示层的解耦。

缺点

  • MVC只是一种指导思想,因而它没有明确的规定各个模块具体应该怎样交互和联系,这使得使用MVC开发的程序其结构总是千奇百怪的,这些千奇百怪的结构也有着各自独特的优势与缺陷。
  • 另外在Android中,XML作为View层功能太羸弱,许多的界面相关的代码不得不写到Activity中,而Activity同时又作为Controller协助View处理用户事件,这使得Activity的职责相当不纯粹。因此在Android中,MVC的Controller和View其实是没有分离的,形成了一种View-Model的结构。

MVP架构

起源与发展

在上文中,我们提到了起源于Web的一种MVC架构变体,这套架构模式除了被广泛应用于Web后端(比如SpringMVC框架),也反哺了客户端架构的演化。

随着GUI框架的不断进化与完善,View层具备了独立的捕获交互事件以及处理交互事件的能力,因此处理交互的逻辑从Controller转移到了View中,这使得Controller直接没有存在的必要了。这种情况也同样体现在Android中:Activity和XML View组成了新View层,而不再需要Controller的角色。

前面提到,Controller在协助View处理用户事件时,还顺便揽下了一部分介于View和Model之间的业务逻辑,比如在View和Model之间传递数据和请求,将Model层返回的数据做一下转换再交给View渲染等等。而Controller的消失则让这部分逻辑不得不去再次回到View或Model中,进而使得View和Model相互耦合起来。

为此,人们便借鉴了Web中的MVC架构,View必须通过Controller向Model发起请求,Controller收到结果再去更新View。这样一来,View和Model就被隔离开了,同时之前那些业务逻辑又有合适的去处了。

长得像MVP的MVC

在这套架构模式中,因为Controller不再作为系统与用户的连接,控制器这个名称似乎有些不合理,于是便改名为Presenter(主持人), 从名称也可以想到,这是一个协调View和Model工作的角色。

MVP架构模式解除了View与Model耦合,避免了业务逻辑出现View中,使在MVC中混乱的数据流/事件流变得清晰起来。 再后来,人们发现Presenter与View之间存在强耦合,这两部分不好独立的进行开发与测试,便运用依赖倒置原则(DIP)提取出接口,让它们相互依赖接口,便有了如今的MVP。

使用了DIP的MVP

角色划分

  • Model:用来保存程序的数据状态,比如数据存储,网络请求等。
  • View:GUI组件构成,向用户展示数据,响应用户事件等。
  • Presenter:作为沟通View和Model的桥梁,处理来自View层转发的用户请求,从Model层检索数据,通知View层改变界面等。

两种常见的MVP

Passive View

Passive View MVP是最典型的,在该架构模式中,View层是被动的,也就是说,View层本身不会主动改变自己的任何状态,所有状态都交由Presenter间接改变。

Passive View MVP

Supervising Controller

Supervising Controller MVP与Passive View MVP的不同之处在于前者并没有完全解除View与Model之间的耦合, 而是使用DataBinding这类的框架将View属性与Model中部分数据进行绑定,简单的数据展示直接由View与Model进行同步,而 Presenter只处理复杂的状态同步与模块协调等工作。

Supervising Controller MVP

解决的问题

  1. 规范了传统MVC中混乱的数据流向/事件流向。
  2. 将用户事件捕获从Controller(Presenter)中抽离出来,使Controller(Presenter)可以专注于业务逻辑。
  3. 解除了View与Model之间的强耦合,使View层能更专注于UI处理。
  4. 解除了View与Presenter之间的强耦合,使一个Presenter能够应用于多个View,同时各个模块可以独立开发、独立测试。

存在的问题

  • 会引入大量的接口,增加代码结构的复杂性(查看调用逻辑会很麻烦)。
  • Presenter层持有View,导致该层不得不感知View的声明周期,带来额外的复杂度。

MVVM架构

起源与发展

从Supervising Controller到Presentation Model

在前文中,我们提到,Supervising Controller MVP使用数据绑定直接将View与Model中部分属性进行绑定,在一定程度上减少了视图与模型之间同步的代码。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

结尾

最后小编想说:不论以后选择什么方向发展,目前重要的是把Android方面的技术学好,毕竟其实对于程序员来说,要学习的知识内容、技术有太多太多,要想不被环境淘汰就只有不断提升自己,从来都是我们去适应环境,而不是环境来适应我们!

当程序员容易,当一个优秀的程序员是需要不断学习的,从初级程序员到高级程序员,从初级架构师到资深架构师,或者走向管理,从技术经理到技术总监,每个阶段都需要掌握不同的能力。早早确定自己的职业方向,才能在工作和能力提升中甩开同龄人。

想要拿高薪实现技术提升薪水得到质的飞跃。最快捷的方式,就是有人可以带着你一起分析,这样学习起来最为高效,所以为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。

当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。

高级UI,自定义View

UI这块知识是现今使用者最多的。当年火爆一时的Android入门培训,学会这小块知识就能随便找到不错的工作了。

不过很显然现在远远不够了,拒绝无休止的CV,亲自去项目实战,读源码,研究原理吧!

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

存中…(img-Vhh0KOoZ-1713807885873)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值