小米一面:说说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://www.mzph.cn/bicheng/2419.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringMVC中的文件上传和中英文名称文件下载

一、文件上传 前端&#xff1a; <% page language"java" contentType"text/html;charsetUTF-8"pageEncoding"UTF-8"%> <! DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN""http://www.w3.org/TR/html4…

如何使用 Fly.io 和 Tigris 部署 Next.js 应用

在本教程中&#xff0c;您将学习到应用部署平台 Fly.io 和全球分布式的 S3 兼容对象存储服务 Tigris。 这两个平台密切相关&#xff0c;使它们成为您项目的绝佳选择。您可以从 Fly.io 获得应用部署体验&#xff0c;并从 Tigris 获得对象存储功能。 应用部署相当简单易懂&…

2001-2021年上市公司制造业智能制造词频统计数据

2001-2021年上市公司制造业智能制造词频统计数据 1、时间&#xff1a;2001-2021年 2、来源&#xff1a;上市公司年报 3、指标&#xff1a;年份、股票代码、行业名称、行业代码、所属省份、所属城市、智能制造词频、智能制造占比(%) 4、范围&#xff1a;上市公司 5、样本量…

探索嵌入式系统:快速入门指南概览

✨✨ 欢迎大家来访Srlua的博文&#xff08;づ&#xffe3;3&#xffe3;&#xff09;づ╭❤&#xff5e;✨✨ &#x1f31f;&#x1f31f; 欢迎各位亲爱的读者&#xff0c;感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢&#xff0c;在这里我会分享我的知识和经验。&am…

OpenHarmony实战开发-性能测试工具SmartPerf Editor使用指导

概述 SmartPerf Editor是一款PC端桌面应用&#xff0c;通过监测、采集应用运行时FPS、CPU、GPU、Memory、Battery、Network等性能数据&#xff0c;帮助开发者了解应用的性能状况。SmartPerf Editor还集成了DrawingDoc功能&#xff0c;可录制Render Service绘制指令&#xff0c…

Android Perfetto 监控应用启动耗时

Perfetto 是一个 Google 开发的用于安卓系统性能监控和调试的工具&#xff0c;它旨在提供实时数据收集和可视化功能&#xff0c;帮助我们分析和优化应用程序的性能表现。Perfetto 可以捕获系统事件、CPU、内存、网络、GPU 等性能指标数据&#xff0c;并将其记录为轻量级的 Trac…

开发环境中的调试视图(IDEA)

当程序员写完一个代码时必然要运行这个代码&#xff0c;但是一个没有异常的代码却未必满足我们的要求&#xff0c;因此就要求程序员对已经写好的代码进行调试操作。在之前&#xff0c;如果我们要看某一个程序是否满足我们的需求&#xff0c;一般情况下会对程序运行的结果进行打…

茶饮门店本地生活抖音团购运营方案计划书

【干货资料持续更新&#xff0c;以防走丢】 茶饮门店本地生活抖音团购运营方案计划书 部分资料预览 资料部分是网络整理&#xff0c;仅供学习参考。 PPT可编辑80页&#xff08;完整资料包含以下内容&#xff09; 目录 抖音本地生活运营方案 1. 账号基础搭建与优化 - 门店账号…

Php-WebView 现代跨平台 GUI分享

GitHub :php-webview 一个用于 C/C 的小型跨平台 Web 视图库&#xff0c;用于构建现代跨平台 GUI。 该项目的目标是为最广泛使用的平台创建一个通用的 HTML5 UI 抽象层。 它支持双向 JavaScript 绑定&#xff08;从 C/C 调用 JavaScript 和从 JavaScript 调用 C/C&#xff09;。…

ClickHouse 高可用之副本

文章目录 ClickHouse 副本支持副本的引擎配置高可用副本副本应用1.副本表概述2.创建副本表3.写入模拟数据4.副本验证 扩展 —— 在 Zookeeper 中查看副本表信息 ClickHouse 副本 ClickHouse 通过副本机制&#xff0c;可以将数据拷贝存储在不同的节点上。这样&#xff0c;如果一…

我的世界服务器设计思路应该是什么样?

我的世界服务器设计思路可以从这4个方面展开&#xff1a;1.选择你喜欢的东西&#xff1b;2.认识你的极限&#xff1b;3.注入新鲜元素&#xff1b;4.让服务器变得享受且有回报。 1.选择你喜欢的东西 设计服务器的首要规则是创造一些你自己会积极享受玩的东西。没有人愿意花费宝…

在Spring boot中指定随机可用的端口

​ 正常情况下每个spring boot启动都有固定的端口&#xff0c;也就是8080&#xff0c;如果启动多个项目&#xff0c;很容易出现端口冲突&#xff0c;那么怎么解决这个问题呢&#xff1f; 解决方案1&#xff1a; random 随机端口 ​ 在spring boot中&#xff0c;可以通过${ran…

linux的一些实用操作

快捷键 强制停止 ctrlc强制停止或退出命令的输入 退出登出 ctrld强制退出用户登录或退出某些程序的专属页面&#xff08;如py&#xff09; ps&#xff1a;不能退出vi/vim 历史命令搜索 history可以查看历史命令&#xff0c;用来复制粘贴 在使用history之后&#xff0c;…

fnm:Rust开发的高效Node版本管理工具

简介 fnm 是一个基于 Rust 开发的 Node 版本管理工具&#xff0c;它的目标是提供一个快速、简单且可靠的方式来管理 Node.js 的不同版本。同时&#xff0c;它是跨平台的&#xff0c;支持 macOS、Linux、Windows。&#x1f680; Fast and simple Node.js version manager, buil…

pycharm-git 配置(1)

1.安装git2.pycharm 中配置git 插件 弹出Git版本号&#xff0c;即配置成功。3.创建本地仓库 VCS->VCS operations->create repository->设置本地目录 左下角可以看到git本地仓库git可以看到push,commit。 4.配置远方仓库&#xff0c;此时确保git上是有这个项目…

【linux】chmod权限开放(整个文件夹)

文章目录 起因权限查看权限修改 失败权限修改成功 起因 想要共享conda环境给同事&#xff0c;发现同事没权限。 权限查看 ls #查看当前目录 ls -l # 查看当前目录的东西和权限正常情况下是显示 三个rwx分别属于user&#xff0c;group&#xff0c;others 前面第一个rwx 是针…

美容预约小程序:简单三步,开启高效预约模式

在当今的数字化时代&#xff0c;一个小程序可以极大地提高美容院的效率和客户满意度。下面我们将详细说明如何通过以下步骤来搭建一个美容院预约小程序。 首先&#xff0c;你需要注册并登录到乔拓云网&#xff0c;这是 一个在线平台&#xff0c;可以帮助你快速创建并管理你的小…

腾讯云服务器,部署mysql数据库后无法远程访问?

一&#xff0c;首先确定自己部署的数据库&#xff0c;是否可以正常登录&#xff0c;验证部署是否是否成功 mysql -u root -p二、放开mysql远程访问权限&#xff0c;依次输入这些命令 create user root% identified with mysql_native_password by xxxxx; grant all privilege…

k8s学习(三十六)centos下离线部署kubernetes1.30(单主节点)

文章目录 服务器准备工作一、升级操作系统内核1 查看操作系统和内核版本2 下载内核离线升级包3 升级内核4 确认内核版本 二、修改主机名/hosts文件1 修改主机名2 修改hosts文件 三、关闭防火墙四、关闭SELINUX配置五、时间同步1 下载NTP2 卸载3 安装4 配置4.1 主节点配置4.2 从…

Linux sudo suid提权练习

题目比较简单&#xff0c;可以利用sudo和多种suid程序提权&#xff0c;做个记录 进入靶场题目环境 获得节点信息 远程连接上 执行命令id&#xff0c;发现只是admin普通账户 sudo提权 发现存在 /usr/bin/vim, /usr/bin/bash, /usr/bin/more, /usr/bin/less, /usr/bin/nano, /…