MVC与MVP设计模式

MVC模式 (Model-View-Controller)

基本概念

MVC是一种将应用程序分为三个核心组件的设计模式:

  • Model(模型): 负责数据和业务逻辑

  • View(视图): 负责显示数据和用户界面

  • Controller(控制器): 处理用户输入并更新模型和视图

交互流程

cpp 复制代码
┌─────────┐    ┌───────────┐    ┌──────┐
│   View  │ ←→ │ Controller│ ←→ │ Model│
└─────────┘    └───────────┘    └──────┘
     ↑                              │
     └──────────────────────────────┘
  1. 用户与View交互(如点击按钮)

  2. View将用户操作传递给Controller

  3. Controller处理输入,可能需要更新Model

  4. Model更新后通知View(通常通过观察者模式)

  5. View从Model获取最新数据并更新显示

特点

  • View和Model之间存在直接通信

  • Controller相对较轻,主要作为中介

  • 常用于Web框架如Spring MVC、Ruby on Rails等

MVP模式 (Model-View-Presenter)

基本概念

MVP是MVC的变体,主要区别在于:

  • Presenter取代了Controller

  • View和Model完全解耦

交互流程

cpp 复制代码
┌──────┐    ┌───────────┐    ┌──────┐
│ View │ ←→ │ Presenter │ ←→ │ Model│
└──────┘    └───────────┘    └──────┘
  1. 用户与View交互

  2. View将事件委托给Presenter

  3. Presenter处理业务逻辑,可能需要更新Model

  4. Model更新后通知Presenter(不是直接通知View)

  5. Presenter从Model获取数据并更新View

特点

  • View和Model完全分离,通过Presenter通信

  • Presenter比Controller更重,包含更多展示逻辑

  • View通常是被动的,只负责显示

  • 常用于桌面应用和Android开发

关键区别图示

cpp 复制代码
MVC:
┌──────┐       ┌───────────┐       ┌──────┐
│ View │ ←───→ │Controller │ ←───→ │ Model│
└──────┘       └───────────┘       └──────┘
   ↑                                 │
   └─────────────────────────────────┘

MVP:
┌──────┐       ┌───────────┐       ┌──────┐
│ View │ ←───→ │Presenter  │ ←───→ │ Model│
└──────┘       └───────────┘       └──────┘
(无直接View-Model通信)

优缺点比较

MVC优点

  • 结构简单直接

  • 开发速度快

  • 适合小型到中型应用

MVC缺点

  • View和Model耦合

  • 大型应用中Controller可能变得臃肿

  • 单元测试较困难

MVP优点

  • 更好的关注点分离

  • 更易于单元测试

  • View和Model完全解耦

  • 适合复杂UI逻辑

MVP缺点

  • 需要更多样板代码

  • Presenter可能变得复杂

  • 学习曲线略高

实际应用示例

MVC示例(Web应用)

cpp 复制代码
// Model
public class User {
    private String name;
    // getters/setters
}

// View (JSP)
<html><body>Hello ${user.name}</body></html>

// Controller
@Controller
public class UserController {
    @GetMapping("/user")
    public String getUser(Model model) {
        model.addAttribute("user", new User("Alice"));
        return "userView";
    }
}

MVP示例(Android)

cpp 复制代码
// Model
public class User {
    private String name;
    // getters/setters
}

// View接口
public interface UserView {
    void showUserName(String name);
}

// Presenter
public class UserPresenter {
    private UserView view;
    private User user;
    
    public UserPresenter(UserView view) {
        this.view = view;
        this.user = new User("Bob");
    }
    
    public void loadUser() {
        view.showUserName(user.getName());
    }
}

// Activity实现View接口
public class UserActivity extends AppCompatActivity implements UserView {
    private UserPresenter presenter;
    
    protected void onCreate(Bundle b) {
        presenter = new UserPresenter(this);
        presenter.loadUser();
    }
    
    public void showUserName(String name) {
        textView.setText(name);
    }
}
相关推荐
BD_Marathon1 天前
设计模式——合成复用原则
设计模式·合成复用原则
书院门前细致的苹果1 天前
设计模式大全:单例、工厂模式、策略模式、责任链模式
设计模式·责任链模式·策略模式
BD_Marathon2 天前
设计模式——依赖倒转原则
java·开发语言·设计模式
BD_Marathon2 天前
设计模式——里氏替换原则
java·设计模式·里氏替换原则
jmxwzy2 天前
设计模式总结
设计模式
J_liaty2 天前
23种设计模式一代理模式
设计模式·代理模式
MSTcheng.3 天前
探索昇腾底层逻辑:从ops-nn视角解读aclnn两阶段设计理念
mvc
苏渡苇3 天前
优雅应对异常,从“try-catch堆砌”到“设计驱动”
java·后端·设计模式·学习方法·责任链模式
短剑重铸之日3 天前
《设计模式》第十一篇:总结
java·后端·设计模式·总结
feasibility.3 天前
AI 编程助手进阶指南:从 Claude Code 到 OpenCode 的工程化经验总结
人工智能·经验分享·设计模式·自动化·agi·skills·opencode