当前位置: 首页 > article >正文

架构设计系列(三):架构模式

一、概述

关于移动应用开发中常见的架构模式,这些模式是为了克服早期模式的局限性而引入。常见的 架构模式有:
MVC, MVP, MVVM, MVVM-C, and VIPER
在这里插入图片描述

二、MVC, MVP, MVVM, MVVM-C, and VIPER架构模式

  MVC、MVP、MVVM、MVVM-C 和 VIPER 是移动应用开发中常见的架构模式。它们的目标是将代码分离为不同的职责模块,以提高可维护性、可测试性和可扩展性。

  • MVC(Model-View-Controller)
      mvc 由 model层、view层和controller层组成。model层负责数据逻辑和业务逻辑,view层负责 UI 展示,controller 层负责处理用户输入,更新 Model 并刷新 View。
      其优点是简单易用,分离了数据、UI和逻辑,适合小型应用,用于一些快速需要快速开发场景中。
      但随着业务的及代码量的增长,Controller层容易变得臃肿,view和model之间耦合较高,会出现“万能类”,难以测试及维护

  • MVP(Model-View-Presenter)
      MVP由model层、view层和presenter层组成
    presenter层负责处理用户输入,更新 Model 并更新 View,model层负责数据逻辑和业务逻辑,view层负责 UI 展示,并通过接口与 Presenter 交互。
      其优点是view与model完全解耦,方便测试,Presenter 作为中间层,减少了 Controller 的臃肿问题
      但随着业务的增长Presenter 仍然可能变得复杂,同时需要手动管理 View 和 Presenter 的生命周期。

  • MVVM(Model-View-ViewModel)
      MVVM由model层、view层和ViewModel层组成。Model负责数据逻辑和业务逻辑,View负责 UI 展示,并通过数据绑定与 ViewModel 交互,ViewModel负责将 Model 的数据转换为 View 可以使用的形式,并处理用户输入。
      数据绑定减少了手动更新 UI 的代码。View 和 ViewModel 解耦,便于测试和维护。
      数据绑定可能增加调试难度。对于简单应用可能显得过于复杂。

  • MVVM-C(Model-View-ViewModel-Coordinator)
      MVVM-C由model层、view层和ViewModel层及Coordinator层组。 Model负责数据逻辑和业务逻辑,View负责 UI 展示,并通过数据绑定与 ViewModel 交互,ViewModel负责将 Model 的数据转换为 View 可以使用的形式,并处理用户输入。引入 Coordinator负责导航和模块之间的交互。
      其优点是引入 Coordinator 进一步解耦导航逻辑,适合复杂的导航场景。

  • VIPER(View-Interactor-Presenter-Entity-Router)
      VIPER由View,Interactor、Presenter、Entity及Router组成。View负责 UI 展示,并将用户输入传递给 Presenter,Interactor负责业务逻辑和数据操作,Presenter负责从 Interactor 获取数据并更新 View,
    Entity负责数据模型,Router负责导航和模块之间的交互。
      其优点是高度模块化,职责分离明确,适合大型团队和复杂应用。
      与此同时也增加了代码量和复杂性,对于开发团队的学习成本较高。

三、总结

以下是这些架构模式的主要区别:

模式核心特点优点缺点适用场景
MVC分离 Model、View 和 Controller简单易用Controller 臃肿,耦合高小型应用
MVP引入 Presenter 解耦 View 和 Model便于测试Presenter 可能复杂中型应用
MVVM引入 ViewModel 和数据绑定高度解耦,便于测试数据绑定调试复杂大型应用
MVVM-C引入 Coordinator 解耦导航逻辑适合复杂导航场景增加了复杂性大型应用,复杂导航
VIPER高度模块化,职责分离明确适合大型团队代码量大,学习曲线高超大型应用

选择哪种架构模式取决于应用的规模、团队的规模以及具体的需求。小型应用可以选择 MVC 或 MVP,而大型应用则更适合 MVVM、MVVM-C 或 VIPER。


http://www.kler.cn/a/549922.html

相关文章:

  • 备战蓝桥杯 Day2 枚举 Day3 进制转换
  • FFmpeg源码:av_strlcpy函数分析
  • kamailio中的PV,PV Headers,App Lua,Dialog,UUID,Dianplan等模块的讲解
  • Unity状态机的实现方法二
  • Vue3(3)
  • 【Oracle】层次查询步骤,理解 where 条件执行顺序
  • 项目上传github步骤
  • DeepSeek与医院电子病历的深度融合路径:本地化和上云差异化分析
  • MATLAB图像处理:图像分割方法
  • 【go语言规范】关于接口设计
  • YOLOv11目标检测:解密mAP50与mAP的背后秘密
  • 代码随想录刷题攻略---动态规划---子序列问题1---子序列
  • java八股文-redis
  • python的类装饰器
  • 【系列专栏】银行IT的云原生架构-存储架构-数据库部署 10
  • 青少年编程与数学 02-009 Django 5 Web 编程 16课题、权限管理
  • rtsp rtmp 跟 http 区别
  • Kubernetes控制平面组件:etcd高可用集群搭建
  • 250214-java类集框架
  • React 前端框架搭建与解析