什么是MVC软件架构模式_mvc架构的设计思路

什么是MVC软件架构模式_mvc架构的设计思路缘起:作为程序员,很容易天天被业务追逐着,抽不开时间修炼。有一天突然停了一下,忽地就会有一种怅然的感觉,过去的那些日子我学到了什么?有人很认真地说自己有10年经验,有人笑说你不过是一年经验用了10年而已。

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

一、缘起

    作为程序员,很容易天天被业务追逐着,抽不开时间修炼。有一天突然停了一下,忽地就会有一种怅然的感觉,过去的那些日子我学到了什么?

有人很认真地说自己有10年经验,有人笑说你不过是一年经验用了10年而已。

二、师傅领进门

做人,做事,做架构师–架构师能力模型解析这篇文章,已经把架构师的能力总结好了,简单就是两个词,做人、做事。在上文中,作者提出了作为架构师做事需要做好的事情如下图,特别有道理,特别值得再细细品味一下

什么是MVC软件架构模式_mvc架构的设计思路


什么样的架构师是一个会做事的架构师?既能做设计、做决策、关键时刻还要自己能光着膀子上。也就是下得了厨房,上得了厅堂。

架构师是一个有全局观的设计师,有全局观的程序员。大家都在低着头走路的时候,他偶尔看了看天上的天象。

三、读万卷书、行万里路

架构模式的种类 一文把模式按层次分成三种:架构模式(Architectural Pattern)、设计模式(Design Pattern)、成例(Idiom)。成例有时称为代码模式(Coding Pattern)。这三者之间的区别在于三种不同的模式存在于它们各自的抽象层次和具体层次上。架构模式是一个系统的高层次策略,涉及到大尺度的组件以及整体性质和力学。架构模式的好坏可以影响到总体布局和框架性结构。设计模式是中等尺度的结构策略。这些中等尺度的结构实现了一些大尺度组件的行为和它们之间的关系。模式的好坏不会影响到系统的总体布局和总体框架。设计模式定义出子系统或组件的微观结构。代码模式(或成例)是特定的范例和与特定语言有关的编程技巧。代码模式的好坏会影响到一个中等尺度组件的内部、外部的结构或行为的底层细节,但不会影响到一个部件或子系统的中等尺度的结构,更不会影响到系统的总体布局和大尺度框架。 


今天只想探索最酷炫的架构模式。
架构的美只有架构师的眼中才能看得到。大家都看着的只是一堆砖泥瓦的时候,只有架构师最清楚这个地方以后会长出来一个多么漂亮的高楼。

main函数入口:
所有的系统,都有一个入口。大家都是从最简单的main函数开始,只是为何有的就只是print一个helloword,有的在做高密度的计算把CPU耗成100%,有的起了一个健壮的服务,有的建起了一个漂亮的花花世界。
就像还是种子的时候看起来,种子样子都是差不多的,最后长成的样子会是千差万别。
一定要看好main的入口,一个看不起眼的地方,也是万物萌芽的地方。

ApplicationContext:
好多系统都有一个ApplicationContext,小白的话可能没有注意到它。更多的人是瞥了一眼ApplicationContext,当作没存在直接上去就搞业务。这样的问题就是导致建的房子就像是一栋没有地基的房子,错乱搭建起来,杂乱无章。
很多系统ApplicationContext做了很多奇奇怪怪的初始化,然后这个系统的地基打好了。
然后很多人可以在上面工作了,很多很多人。
系统的地基就是系统的核心框架,就是在ApplicationContext里面加载完毕的。

基础服务和common组件:
系统的框架已经在ApplicationContext中搭好了。
框架上首先运行着系统的心脏,
也就是系统的基础服务和common组件,是工业时代的水和电。
很多系统都有一个ServiceManager.getService(xxx),或者是xxxFactory.createXXX()

业务单元:
系统框架已经搭好,基础服务和公共组件库也建好了以后,业务单元就可以百花齐放了。
很多人
可以同时用系统共享的水和电一起开工建房子了,然后直接一拼,联排别墅已经建好,这也太神速了吧。
所以很多人以为自己建房子挺快的,以为建一个房子很容易,其实他更像是在装修一个毛坯房。

一个架构模式描述软件系统里的基本的结构组织或纲要。 架构模式提供一些事先定义好的子系统,指定它们的责任,并给出把它们组织在一起的法则和指南。
  • MVC 模式 一个架构模式常常可以分解成很多个设计模式的联合使用。 MVC 模式常常包括调停者(Mediator)模式、策略(Strategy)模式、合成(Composite) 模式、观察者(Observer)模式等。
  • Layers(分层)模式 有时也称 Tiers 模式
  • Blackboard(黑板)模式
  • Broker(中介)模式
  • Distributed Process(分散过程)模式
  • Microkernel(微核)模式

架构模式常常划分成如下的几种:

模块结构(From Mud to Structure)型。帮助架构师将系统合理划分,避免形成一个对象的海洋。 包括 Layers (分层)模式、 Blackboard (黑板)模式、 Pipes/Filters (管道/过滤器)模式等。

分散系统(Distributed Systems)型。为分散式系统提供完整的架构设计,包 括像 Broker(中介)模式等。

人机互动(Interactive Systems)型,支持包含有人机互动介面的系统的架构设计,例子包括 MVC(Model-View-Controller)模式、PAC (Presentation-Abstraction-Control)模式等。

Adaptable Systems 型, 支持应用系统适应技术的变化、 软件功能需求的变化。 如 Reflection(反射)模式、Microkernel(微核)模式等。


四、悟
最了解的软件架构模式就是分层和MVC和插件

为什么要分层?
分层就是为了分类,每一个层都有自己的职责。
东西多了就自然而然分层,物以类聚。
建个小屋是不需要分层的,房子高了才需要分层。每一层都有自己服务的层。B2就是停车场、B1是食堂、1层是大堂……
分层依据的主要设计原则就是:单一职责、依赖倒置

网络方面有熟知的 OSI 七层模型
应用程序框架方面有:持久层–〉服务层–〉应用层 

为什么要有MVC?
类与类之间的关系越密切,耦合度越大,当一个类发生改变时,对另一个类的影响也越大

房子各式各样的设计都有,但是里面的组件是可以共享的
外面对接的是Controller,从数据服务取出数据拼成Model,画到View上去
应用层逻辑比较复杂,交互较多。
MVC以来的主要设计原则:单一职责、迪米特法则又叫最少知道原则、组合模式、接口隔离

为什么要插件框架?
每个人都可以把自己的房间打扮成自己想要的模样,
水和电都是共享的,但是房间确实不一样的,那就是各式各样的插件了

悟的时候,时光要慢了下来,偶尔的灵光一现自己也能感觉到。
别人看我是一个搬砖工,我觉得自己在建一座宏伟的教堂。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/183631.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • ElasticSearch集群搭建图文解析

    ElasticSearch集群搭建图文解析/前言/      ElasticSearch作为一个分布式搜索引擎有着广泛的应用场景,而搜索服务在在一个项目中的权重还是比较高的,所以我们要想办法去提高搜索服务的可用性,这就是ElasticSearch集群的作用,为搜索服务提供高可用的特性       何为高可用呢,其实就是字面意思,假设我们的搜索服务可以一直不停的提供服务,那么高可用性就是100%,

    2022年10月13日
  • python编程入门与案例详解-"Python小屋”免费资源汇总(截至2018年11月28日)…「建议收藏」

    python编程入门与案例详解-"Python小屋”免费资源汇总(截至2018年11月28日)…「建议收藏」原标题:"Python小屋”免费资源汇总(截至2018年11月28日)为方便广大Python爱好者查阅和学习,特整理汇总微信公众号"Python小屋”开通29个月以来推送过的700多篇文章清单,如果需要本清单的电子版,可以在公众号后台发送消息"资源汇总”获取下载地址。非计算机专业《Python程序设计基础》教学参考大纲计算机相关专业"Python程序设计”教…

  • python resize函数怎么用_python cv2.resize函数high和width注意事项说明「建议收藏」

    在opencv中获取图片的尺寸的方法是:importcv2img=cv2.imread(path)img.shape返回的是三维数组(high,width,3),当我们需要对图像进行缩放时需要用到cv2.resize()函数:#缩放到原来的二分之一img=cv.resize(img,(int(width/2),int(high/2)))此时需要传入的形状又是(width,…

  • hypervisor kvm_docker vmware

    hypervisor kvm_docker vmwareLinuxhypervisor介绍荣涛2021年10月14日1.引言管理程序对操作系统所做的事情就像操作系统对进程所做的大致相同。它们为执行提供隔离的虚拟硬件平台,从而提供对底层机器的完全访问的错觉。但并非所有的虚拟机管理程序都是一样的,这是一件好事,因为Linux是关于灵活性和选择的。本文首先简要介绍虚拟化和管理程序,然后探讨几个基于Linux的管理程序。2.平台设备模拟平台虚拟化是关于在两个或多个操作系统之间共享一个平台,以便更有效地利用资源。但平台不仅仅意味着处理

  • goland 2021 激活码-激活码分享

    (goland 2021 激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。https://javaforall.cn/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~4…

  • oracle字符串拼接

    一、“||”拼接类似于“+”号二、CONCAT()函数除了“||”,Oracle还支持使用CONCAT()函数进行字符串拼接,但是只支持两个字符:三、多个CONCAT()函数嵌套如果需要拼接多个字符串,可以进行嵌套:…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号