小米一面:说说MVC与设计模式的关系

前言

大家好,我叫阿杆,不叫阿轩。

先来看看面试环节吧。

面试官:请说说MVC模式是基于哪种设计模式的?

求职者:MVC本身不就是一种设计模式吗?

面试官:我的意思是,MVC是基于23中设计模式中的哪一种?

求职者:难道MVC不是那23种当中的?

面试官:…………

好吧,这种情况下,大概率是求职者对设计模式的学习比较少,就连我这种没正经学过设计模式的混子,也知道23种设计模式当中没有MVC。

回归正题,其实MVC模式是基于观察者模式的,你仔细想想,MVC中的Model其实对应的是观察者模式的被观察对象(也叫主题或目标),而View则对应的则是观察者的角色。

如果你想不清楚的话,就继续往下看吧,我带你分析一波。

MVC模式

MVC 模式代表 Model-View-Controller(模型-视图-控制器) 模式。

  • 模型(Model):负责管理应用程序的数据和业务逻辑。
  • 视图(View):显示模型的数据,通常是用户界面元素。
  • 控制器(Controller):控制器作用于模型和视图上,它控制数据流向模型对象,并在数据变化时更新视图,使视图与模型分离开。

这种模式的目的是实现动态的程序设计,简化对程序的修改和扩展,并使程序某一部分的重复利用成为可能。通过将信息的内部表示与信息的呈现方式分离,使得组件具有较好的重用性。

例如,同一个程序可以使用不同的表现形式来展示相同的数据,比如一批统计数据可以分别用柱状图、条形图来表示。

MVC模式示例图

应用场景

几乎每一个 Web 项目都会使用到 MVC 模式,所以有许多的框架都对此做了集成和封装的工作,像我们 Java 程序员最常见的就是平时使用的 SpringMVC 框架了。

<dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>5.0.1.RELEASE</version>
</dependency>

当然,现在的 Web 项目中一般只有 Controller 和 Model ,并不存在所谓的 View,那是因为目前流行的前后端分离开发模式,已经将 View 交给前端程序员去做了。

早些年的 Java 程序员,会写一种叫 jsp 的东西,就算你没写过,也多少听说过吧。这玩意就是用来展示页面的,也就是 MVC 中的 View 。

那时候的项目结构,是这样子的:

image-20240313183907174

比现在的结构多了个web文件夹,里面就包含了View层的代码 index.jsp,而 jsp 的代码呢,长这样:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html><head><title>$Title$</title></head><body><%System.out.println("hello jsp");%></body>
</html>

眼熟不🤣,其实就是 HTML 和 Java 的结合写法,最终返回给浏览器的就是一个 HTML 页面。

R(1)

即使现在后端程序员不再写 View 层了,但其实大家的开发思路还是和原来一致的,只是把 View 交给了前端程序员去实现。

除了SpringMVC,服务端的MVC框架还有:Struts、ASP.Net MVC,前端的MVC框架还有:angularjs、reactjs等。

观察者模式

前面已经说了,MVC模式就是基于观察者模式的,所以我也不绕弯子,直接给大家介绍一下这个观察者模式

观察者模式是我们常说的23种设计模式中的一种,它定义了对象之间的依赖关系,使得当一个对象的状态发生改变时,所有依赖于它的对象都会得到通知并自动更新。

观察者模式中包含4个角色:

  • 目标(Subject):也称为主题,它是指被观察的对象。目标中定义了一个观察者的集合,一个目标可以接受任意数量的观察者,同时也提供了一些方法,例如:添加观察者 add() 、删除观察者 delete() 、通知所有观察者 notify() 等。目标类可以是抽象类、具体类或者接口。
  • 具体目标(ConcreteSubject):具体目标是目标的子类或实现类,通常包含有经常发生改变的数据,当它的状态发生变化时,会向所有的观察者发出通知。如果无需扩展目标类,那具体目标类可以省略。
  • 观察者(Observer):观察者将对目标的改变做出反应,观察者一般定义为接口或抽象类,接口中声明更新数据的方法 update()。
  • 具体观察者(ConcreteObserver):具体观察者实现了抽象观察者的 update() 方法,并且会维护一个指向具体目标的引用。当收到观察者的通知开始执行 update() 方法时,会根据观察者的状态来执行对应的逻辑。

下面是我画的结构图:

观察者模式结构图.drawio

形象一点的话,就是:

1710435451621

好了,差不多就是这样。

纸上谈兵终觉浅,看看应用场景可能会更好理解。

应用场景

熟悉消息队列的同学应该对 发布/订阅模式 有一点了解,就是生产者发送消息到队列中,然后订阅这个队列的所有消费者都会收到这条消息,简单易懂,其实 发布/订阅模式 也是观察者模式的一种变体。

另外,JDK对观察者模式也有支持:

image-20240315010650591

开发者可以直接使用Observer接口和Observable类来作为观察者模式的抽象层,再自定义具体的观察者类和具体观察目标类,这样可以更方便的在Java中应用观察者模式。

MVC与观察者模式的关系

在MVC架构中,模型是观察者模式的主题,视图是观察者。当模型的状态发生改变时,视图会自动更新,反映模型的新状态。

让我们回到前面的这张MVC结构图:

MVC模式示例图

在这张图中,Model层提供的数据是View层所观察的对象,在View层中包含了两个用于显示数据的图表,如果Model层中的数据发生改变,那这两个图表的展示也会随之改变(有可能得刷新一下🤣),所以说MVC中也应用了观察者模式的思想。

懂了吧🤡。

后记

最近刚做完一个私接的项目,从产品设计到上线全程由我负责,每天搞到很晚,还挺累的。今天刚交付完,又要开始找工作喽~ 各位朋友如果有工作能帮忙内推一下的,欢迎私信我,小弟先在此谢过啦~


好了,知识你已经学走了,要不也给我留下点什么?

webwxgetmsgimg (1)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/2980471.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

考研数学|武忠祥强化课VS张宇强化课(全面对比)

在我看来&#xff0c;这两个老师都很好&#xff0c;选者任何一个都不会踩坑&#xff01; 区别就是&#xff0c;这两个老师属于不同的打法&#xff01; 张宇老师属“仙人指路”型&#xff0c;他会在强化课程&#xff0c;把各种类型的习题总结在一起&#xff0c;然后给学生讲清…

docker内实现多机多卡分布式训练

docker内实现多机多卡分布式训练 1. 多台docker宿主机网络配置2. 创建overlay 网络3. 注意 1. 多台docker宿主机网络配置 https://docs.docker.com/network/overlay/ 这里需要创建overlay网络使得多台宿主机的容器可以通过网络连接 初始化swarm集群&#xff0c;并设置主节点&a…

C语言实现扫雷游戏完整实现(上)

文章目录 前言一、新建好头文件和源文件二、实现游戏菜单选择功能三、定义游戏函数四、初始化棋盘五、 打印棋盘函数六、布置雷函数七、玩家排雷菜单八、标记功能的菜单九、标记功能菜单的实现总结 前言 C语言从新建文件到游戏菜单&#xff0c;游戏函数&#xff0c;初始化棋盘…

鸿蒙OpenHarmony【小型系统运行案例】 (基于Hi3516开发板)

运行 启动系统 在完成Hi3516DV300的烧录后&#xff0c;还需要设置BootLoader引导程序&#xff0c;才能运行OpenHarmony系统。 在Hi3516DV300任务中&#xff0c;单击Configure bootloader&#xff08;Boot OS&#xff09;进行配置即可。 说明&#xff1a; DevEco Device Tool…

Leecode125. 验证回文串

文章目录 概要分析整体架构流程小结 概要 提示&#xff1a;这里可以添加技术概要 如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后&#xff0c;短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。 字母和数字都属于字母数字字符。 给你一个字符…

Java线程技术难点

文章目录 Java线程技术涵盖了许多关键概念和复杂机制&#xff0c;其中一些难点包括但不限于以下几个方面&#xff1a; 线程生命周期管理&#xff1a; 状态转换&#xff1a;理解线程的五种基本状态&#xff08;新建、就绪、运行、阻塞、死亡&#xff09;&#xff0c;以及状态之间…

C语言学习/复习30--结构体的声明/初始化/typedef改名/内存对齐大小计算

一、自定义数据类型 二、结构体 1.结构体的定义&#xff08;与数组相对比&#xff09; 2.结构体全局/局部变量的定义 3.typedef对结构体改名 4.匿名结构体类型的声明 注意事项1&#xff1a; 匿名后必须立即创建结构体变量 、 5.结构体与链表节点定义 注意事项1&…

ASP.NET教务管理平台-权限及公共模块设计与开发

摘 要 随着教育改革的不断深化&#xff0c;高等院校的建设与发展对国民整体素质的提高起着越来越重要的作用&#xff0c;建立一套能够适应这些改变的行政管理方案也就显得尤为重要。对于教务处来说&#xff0c;将信息技术用于校务管理中便是迫切的要求。 教务系统中的用户…

黑马Minio(对象存储服务MinIO)

3.1 MinIO简介 MinIO基于Apache License v2.0开源协议的对象存储服务&#xff0c;可以做为云存储的解决方案用来保存海量的图片&#xff0c;视频&#xff0c;文档。由于采用Golang实现&#xff0c;服务端可以工作在Windows,Linux, OS X和FreeBSD上。配置简单&#xff0c;基本是…

Claude国内镜像网站

AI生产力工具Claude 3私藏链接大公开&#xff01; &#x1f680; 国内尚未开放注册&#xff1f;别担心&#xff0c;这里有你想要的解决方案&#xff01; &#x1f517; 私藏链接&#xff1a;https://hiclaude3.cn &#x1f31f; 推荐指数&#xff1a;&#x1f31f;&#x1f…

公园景区伴随音乐系统-公园景区数字IP广播伴随音乐系统建设指南

公园景区伴随音乐系统-公园景区数字IP广播伴随音乐系统建设指南 由北京海特伟业任洪卓发布于2024年4月23日 随着“互联网”被提升为国家战略&#xff0c;传统行业与互联网的深度融合正在如火如荼地展开。在这一大背景下&#xff0c;海特伟业紧跟时代步伐&#xff0c;凭借其深厚…

深入解析 Odoo 在线客服模块 (im_livechat)

深入解析 Odoo 在线客服模块 (im_livechat) Odoo Livechat 是一款集成于 Odoo 平台的实时在线客服系统&#xff0c;它赋予用户在网页界面上直接与客服人员进行即时沟通的能力。本文将逐步剖析 Livechat 的实现细节&#xff0c;从入口模板文件的加载机制&#xff0c;到后端初始…

【Linux】文件描述符——有这篇就够了

目录 前言 预备知识 复习C语言的文件接口 写方式打开文件 追加方式打开文件 读方式打开文件 系统的文件接口 open close write read 文件描述符 0 & 1 & 2 理解文件描述符 文件描述符的分配规则 重定向的本质 dup2 理解Linux下一切皆文件 缓冲区…

09_FreeRTOS任务通知

任务通知 任务通知常用任务通知API函数 任务通知 FreeRTOS 从 V8.2.0 版本开始提供任务通知这个功能&#xff0c;每个任务都有一个 32 位的通知值&#xff0c;在大多数情况下&#xff0c;任务通知可以替代二值信号量、计数信号量、事件组&#xff0c;也可以替代长度为 1 的队列…

自制Apache-Doris 2.0.4镜像Docker部署一Fe和一Be集群及遇到的问题解决

自制Apache-Doris 2.0.4镜像Docker部署一Fe和一Be集群及遇到的问题解决 文章目录 1.前言2.doris是什么&#xff1f;2.1简介2.2介绍2.3使用场景2.4架构 3.官网4.构建部署4.1 构建环境4.2 doris2.0.4的fe和be镜像构建4.2.1 fe2.0.4镜像构建脚本4.2.2 be2.0.4镜像构建4.2.3 启动脚…

Java -- (part16)

一.多线程基础知识 1.进程:在内存中执行的应用程序 2.线程:进程中的一个最小的执行单元 3.并行:在同一时刻,有多个指令在多个CPU上同时执行 4.并发:在同一时刻,有多个指令在单个CPU上交替执行 5.CPU调度 a.分时调度 b.抢占式调度:Java程序 6.主线程:CPU和内存之间开辟的…

C++ CRUD programming for DB

1、ODBC 开放数据库互连&#xff0c;微软主导的关系型数据库接口标准&#xff0c;允许同一代码访问不同DBMS中的数据。小案例&#xff1a;C连接Access数据库----增删改查_c access数据库-CSDN博客 ODBC(Open Database Connectivity&#xff0c;开放数据库连接) ODBC是Microsof…

PCB的通孔、盲孔、埋孔

通孔&#xff1a;是从顶层到底层 盲孔&#xff1a;看不到头&#xff0c;跟井一样&#xff0c;起点永远是第一层 埋孔&#xff1a;是正反都看不到的 总结&#xff1a; 这些孔都是用来切换层的

超详细的Maven安装与使用还有内容讲解

文章目录 作用简介模型仓库 安装配置IDEA配置Maven坐标概念主要组成 IDEA创建Maven项目基本使用常用命令生命周期使用坐标导入jar包 注意事项清理maven仓库更新索引依赖 作用 Maven是专门用于管理和构建Java项目的工具&#xff0c;它的主要功能有&#xff1a; 提供了一套标准化…

力扣HOT100 - 101. 对称二叉树

解题思路&#xff1a; class Solution {public boolean isSymmetric(TreeNode root) {if(root null) return true;return recur(root.left, root.right);}boolean recur(TreeNode L, TreeNode R) {if (L null && R null) return true;if (L null || R null || L.…