谈谈MVC、MVP和MVVM的优缺点

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/github_34402358/article/details/88735473

目前流行的架构模式是MVC、MVP和MVVM这三种,个人比较喜欢后边两种,下边就说一说他们各自的优点缺点。

  1. MVC模式:
    MVC分为Model(模型)、View(视图)、Controller(控制器)三个模块。View(视图层)完成前端的数据展示,Controller(控制层)是对数据的接收和触发事件的接收和传递,Model(模型层)则是对数据的储存和处理,再传递给视图层相应或者展示。如下图

在这里插入图片描述

优点:

  1. 耦合性低
  2. 重用性高
  3. 可维护性高

缺点:

  1. 没有明确的定义
  2. 不适合小型,中等规模的应用程序
  3. 增加系统结构和实现的复杂性
  4. 视图与控制器间的过于紧密的连接
  5. 视图对模型数据的低效率访问

  1. MVP模式:我们项目使用的就是这一套,还是觉得很不错。
    MVP分为 Model(模型)、View(视图)、Presenter(表示器)三部分组成。MVP模式主要是针对Android的MVC模式的升级版本,MVP与MVC最不同的一点是M与V是不直接关联的也是就Model与View不存在直接关系,这两者之间间隔着的是Presenter层,其负责调控View与Model之间的间接交互。如下图:

在这里插入图片描述

优点:

  1. 降低耦合度
  2. 模块职责划分明显
  3. 利于测试驱动开发
  4. 代码复用
  5. 隐藏数据
  6. 代码灵活性

缺点:视图的渲染放在Presenter中,所以视图和Presenter的交互会过于频繁。如果Presenter过多地渲染视图,往往会使得它与特定的视图的联系过于紧密。


  1. MVVM模式:一直期待使用的模式
    MVVM分为Model(数据层)、ViewController/View(展示层)、ViewModel(数据模型)。 MVVM模式主要是减轻Controller层或者View层的压力,实现更加清晰化代码。通过对ViewModel层的封装:封装业务逻辑处理,封装网络处理、封装数据缓存等,让逻辑处理分离出来,并且不需要处理Model数据,使得Controller层或者View层结构简单,条理清晰。如下图:

在这里插入图片描述

优点:

  1. 双向绑定时,当Model变化时,View-Model会自动更新,View也会自动变化。
  2. View的功能进一步的强化,具有控制的部分功能。
  3. 控制器的功能大部分移动到View上处理,大大的对控制器进行了瘦身。

缺点:

  1. 数据绑定使得 Bug 很难被调试。
  2. 数据双向绑定不利于代码重用。
  3. 大的模块,model很大,不利于内存的释放。

猜你喜欢

转载自blog.csdn.net/github_34402358/article/details/88735473