服务化:最常用的应用分层?从MVC开始

0 简介 架构设计和模型

架构模式是针对特定上下文中软件架构中反复出现的问题的通用、可重用的解决方案。

架构模式解决了软件工程中的无数挑战,例如计算机硬件性能限制、高可用性和降低业务风险。

一些常见的体系结构模式包括(MVC)模型-视图-控制器模式、(MVVM)模型-视图-视图-模型、(MVP)客户端-服务器模式、分层模式等。

1 定义MVC,MVP,MTV,MVVM

1.1 MVC模式

MVC架构是Model、View、Controller的缩写,它是把一个应用的输入、处理、输出流程 按照Model、View、Controller的方式进行分离,即应用可被分成三层:模型层、视图层和控制层。 1979年,计算机科学家发明了MVC模式设计。

该模式试图设计一种方法,将大型用户应用程序分解为更小、更易于管理的组件。

MVC模式最初用于Small Talk编程语言。模型-视图-编辑器是模式的初始名称之一,但它已更改为模型-视图-控制器。MVC 模式在整个 1980 年代和 1990 年代初广泛用于桌面应用程序。它在 1990 年代后期开始广泛流行。

模型视图控制器是一种体系结构模式,有助于开发可以轻松开发、测试和维护的应用程序。

模型视图表示器设计模式将控制器替换为表示器,后者在更新视图时操作模型。表示器在 MVVM 设计模式中包含业务逻辑,而视图和模型是隔离的。

模型视图控制器 (MVC) 是一种体系结构模式,它将应用程序的表示层和业务逻辑层分离。它包含三个组件:模型、视图和控制器。模型表示应用程序的数据,视图显示数据,控制器在数据更改时更新视图。 MVC 模式的主要目标是分离关注点以简化可测试性

1.2 MTV模式

在MTV 的解释中,"视图"描述了呈现给用户的数据。数据看起来怎么样并不重要,重要的是哪些数据被呈现。该视图描述了 用户看到了哪些数据,而不是 用户怎么看到数据。这是一个微妙的区别。

所以,在MTV 里,一个"视图(view)"是针对一个特定 URL的回调函数,此回调函数描述了需要展示的数据。

此外,将内容和展示效果分开是很明智的,展示效果就是模板。在MTV 里,一个视图(view)描述了哪些数据会被展示,但是一个视图通常代表了一个模板,这个模板描述了数据是如何被展示的。

那控制器(Controller)在什么位置?在MTV 中,控制器可能指的是框架本身,框架会根据MTV 的 URL 配置,将请求分发到适当的视图(view)。

如果你想要首字母缩写, 则是一个 "MTV " 框架--即 "模型(Model) "、 "模板(Template)" 和 "视图(View). 这种划分更有意义。

归根结底,还是要把事情做好。而且,不管事物怎么命名,MTV 也能以一种最符合某些场景逻辑的方式来完成事情。

1.3 模式对比 MVP & MVVM

  • MVP (Model---View---Presenter)

演示者模式:MVP(Model---View---Presenter)模式中也有三个组件。 这些是模型、视图和演示者。演示器替换 MVP 设计模式中的控制器(在 MVC 中)。

MVP 模式允许更轻松地模拟视图和更高效的应用程序单元测试。 在 MVP 模式中,表示器在更新视图的同时操作模型。

当应用程序必须支持多种用户界面技术时,MVP 设计模式比 MVC 模式更适合。 如果您的用户界面很复杂并且需要大量用户交互,这也是一个不错的选择。

与传统的 MVC 设计相比,MVP 设计模式更适合对应用的用户界面进行自动单元测试。

  • ModelView-ViewModel(MVVM)

ModelView-ViewModel (MVVM) 设计模式是 Martin Fowler 的表示模型设计范式的变体,它建立在流行的 MVC 模式之上。

视图模型有助于分离表示层。表示器包含 MVVM 设计模式中的业务逻辑,并且视图与模型隔离。

视图组件知道表示器,即使表示器忘记视图也是如此。演示器表示用户界面的抽象视图。

被动视图不了解模型。该视图在 MVVM 设计模式中处于活动状态,包括操作、事件和数据绑定信息。

在 MVVM 中,视图不维护状态信息;相反,它与视图模型同步。在 MVVM 中,ViewModel 隔离表示层,并提供用于管理视图状态和操作模型的方法和命令。

MVVM 设计模式中的视图和视图模型使用方法、属性和事件进行通信。

视图和视图模型具有双向数据绑定或双向数据绑定,这保证了视图模型的模型和属性与视图同步。在需要双向数据绑定的应用程序中,MVVM 设计模式是理想的选择。

总体而言,MVVM没有界面,适合大型的安卓平台的应用,核心测试在框架内完成,层的维护性很好,而MVP没有这些特点。 另外MVVM适合单个模型映射多个视图,MVP的演示者和视图通常是一对一的关系。

2 优点和弱点简介

MVC类架构优点:

将关注点清晰地分离
使测试应用程序代码变得更加容易
加速并行开发
促进应用程序层的解耦
促进更好的代码组织、可扩展性和重用

MVC架构的弱点主要表现在:

scss 复制代码
(1)MVC架构的复杂性带来脆弱性。

MVC架构增加了系统结构和实现的复杂性。比如说一个简单的界面,如果严格遵循MVC方式,使得模型、视图与控制器分离,会增加结构的复杂性,并可能产生过多的更新操作,降低运行效率。

scss 复制代码
(2)视图与控制器间紧密连接的脆弱性。

视图与控制器是相互分离但却是联系紧密的部件。 没有控制器的存在,视图应用是很有限的。反之亦然,这样就妨碍了它们的独立重用。

scss 复制代码
(3)视图对模型数据的低效率访问的脆弱性。

依据模型操作接口的不同,视图可能需要多次调用才能获得足够的显示数据。

对未变化数据的不必要的频繁访问也将损害操作性能。

可以说,MVC架构的脆弱性主要表现在缺少对调用者进行安全验证的方式和数据传输不够安全等两个方面。

这些不足也是导致MVC存在比较大的脆弱性、容易招致攻击的主要原因。

scss 复制代码
(4) 实现相对复杂

对于小型应用来说,MVC不是一个好的选择。

3 小结

这里简单对比架构模式和设计模式的区别,架构模式处理系统的主要组件如何协同工作、消息和数据流经系统以及其他结构注意事项。

体系结构模式使用多种组件类型,每种组件类型通常由较小的模块组成。

架构模式是针对特定上下文中软件架构中反复出现的问题的通用、可重用的解决方案。

设计模式是软件应用程序中经常遇到的问题的推荐解决方案和实践。

架构模式处理应用程序的整体结构,而设计模式则关注如何构建程序中的组件。

相关推荐
等一场春雨17 分钟前
领域驱动设计(DDD)四 订单管理系统实践步骤
架构
徊忆羽菲36 分钟前
Linux下php8安装phpredis扩展的方法
linux·运维·服务器
马剑威(威哥爱编程)1 小时前
2025春招 SpringCloud 面试题汇总
后端·spring·spring cloud
PH_modest1 小时前
【Linux跬步积累】——thread封装
linux·运维·服务器
Quantum&Coder1 小时前
Objective-C语言的计算机基础
开发语言·后端·golang
A charmer2 小时前
Linux 进程环境变量:深入理解与实践指南
linux·运维·服务器·开发
嘿嘿2 小时前
Grafana 快速搭建go-metrics 仪表盘备忘
后端·docker·go
计算机学姐3 小时前
基于微信小程序的民宿预订管理系统
java·vue.js·spring boot·后端·mysql·微信小程序·小程序
Code侠客行3 小时前
Scala语言的编程范式
开发语言·后端·golang
努力的小T4 小时前
基于 Bash 脚本的系统信息定时收集方案
linux·运维·服务器·网络·云计算·bash