最早学编程的时候看过一些书,印象深刻的一本书《设计模式解析》,那本书给我后来的工作提供了很大的帮助。

他叫我站在问题模型的立场上指定解决方法,也教会了我软件设计中每个问题都可以细化到到不可再分割的原子性。

在那书以后看到过一些设计模式的书出现。由于本人比较崇尚于权威或者说正统性的学术性书籍,没怎么看其他本书。

最近一些年在网上看到过一些博客中把MVC说成设计模式,这个说法是错误的,MVC实际是软件架构模式。

笔者可以毫不客气的说,工作几年以后,有一些人说MVC是设计模式,基本上是滥竽充数的程序员

因为mvc并没有设计模式中那种问题场景原型,他是一个软件架构的泛化思想模型,比如工厂模式他可以解决需求更新时频繁

维护方法代码,只要传入参数,他就给你对象,比如java中的用class.forname来装载类。

笔者读书不多,对于MVC的粗浅理解如下,供大家参考:

MVC是一种软件架构模式,他模拟人类社会分工,通过分工协作来完成一件事,完成这件事可能需要很多种工种,这里我们可以把

这些工作按角色来理解,理解成软件中的各个层。

比如一个工程项目,公司老板安排设计人员去做标书,标书做完投标,然后把工程给技术部项目经理,项目经理安排技术人员去安装,

技术人员安装好以后反馈给项目经理,项目经理向老板汇报这个标已经完成,至此一个项目结束。

这个流程中:安排、转、汇报几个词语大概反应了一个完整项目中各个角色之间交互的特点,即任务调度及分发,以及

任务结果反馈。

一个项目中如果用到了mvc架构模式,不管项目大小,按群体/角色/职责分工大概有Model层,Controller层,View层。

Model可以理解为基层,做一些苦力,基础性的工作。

Controller可以理解为管理层,他们通常负责下发命令、调度任务

View层可以理解为用户界面及用户交互层。

我们刚刚举例的工程项目中:老板、项目经理他们是Controller层,一个是下发命令,一个调度任务

其中设计部角色 以及技术人员他们是Model层,他们是做基础工作的,他们这一层有一些粗糙的接口,可以和其他角色的人

来交流反馈任务结果。

篇博客临时有点想法,算是吐槽,关于View层笔者没有想到详细的描述方式。

在软件MVC架构中,我们的Model,View,Controller层大家都能划分清楚吧,网上教程很多。

笔者的理解是,不管项目中有没有MVC框架,合理的MVC框架设计应该遵循以下原则:

M层数据持久层,负责与数据库通信,这一层包含数据模型实体类,以及一些CRUD方法。

C层主要负责调度任务,得到V层需求下发命令,最多出现的应该是把任务转发给其他类处理。

例如

DataStoreBLL dbll = new DataStoreBLL();

dbll.doSave(Entity entity){

DataStoreDAL dbal = new DataStoreDAL();

dbal.doSave(entity);

}

实际数据持久化任务通过BLL转发给DAL来处理,BLL只得到处理结果。

C层不应该出现数据库操作代码,例如jdbc的getConnection

View层负责与用户交互,展示处理结果给用户看,可以是web ui,cui,gui,app ui等

各个层之间通信应依赖于抽象(接口或者抽象类)。

MVC是架构模式,而不是设计模式的更多相关文章

  1. 介绍MVC编程架构模式

    MVC(Model/View/Controller)模式是国外用得比较多的一种框架模式,最早是在Smaltalk中出现.MVC包括三类对象. Model——是应用对象 View——是它在屏幕上的表示 ...

  2. MVC三层架构模式编程思想 JSP-Servlet-JavaBean

    MVC(Mdodel-View-Controller)编程模式.把一个Java应用分成三层:模型层.视图层.控制层,各层分别实现各层的功能,整个过程见下图就一目了然了. watermark/2/tex ...

  3. MVC架构模式详细说明

    一.简介: 架构模式是一个通用的.可重用的解决方案,用于在给定上下文中的软件体系结构中经常出现的问题.架构模式与软件设计模式类似,但具有更广泛的范围. 模型-视图-控制器模式,也称为MVC模式(Mod ...

  4. 模型-视图-控制器模式(MVC模式,10种常见体系架构模式之一)

    一.简介: 架构模式是一个通用的.可重用的解决方案,用于在给定上下文中的软件体系结构中经常出现的问题.架构模式与软件设计模式类似,但具有更广泛的范围. 模型-视图-控制器模式,也称为MVC模式.是软件 ...

  5. iOS开发之--MVC 架构模式

    随着项目开发时间的增加,从刚开始那种很随意的代码风格,逐渐会改变,现在就介绍下MVC的架构模式,MVC的架构模式,从字面意思上讲,即:MVC 即 Modal View Controller(模型 视图 ...

  6. Android 四大组件 与 MVC 架构模式

    作为一个刚从JAVA转过来的Android程序员总会思考android MVC是什么样的? 首先,我们必须得说Android追寻着MVC架构,那就得先说一下MVC是个啥东西! 总体而来说MVC不能说是 ...

  7. iOS 架构模式--解密 MVC,MVP,MVVM以及VIPER架构

    本文由CocoaChina译者lynulzy(社区ID)翻译 作者:Bohdan Orlov 原文:iOS Architecture Patterns 在 iOS 中使用 MVC 架构感觉很奇怪? 迁 ...

  8. SpringMVC内容略多 有用 熟悉基于JSP和Servlet的Java Web开发,对Servlet和JSP的工作原理和生命周期有深入了解,熟练的使用JSTL和EL编写无脚本动态页面,有使用监听器、过滤器等Web组件以及MVC架构模式进行Java Web项目开发的经验。

    熟悉基于JSP和Servlet的Java Web开发,对Servlet和JSP的工作原理和生命周期有深入了解,熟练的使用JSTL和EL编写无脚本动态页面,有使用监听器.过滤器等Web组件以及MVC架构 ...

  9. iOS - 架构模式 - 解密 MVC、MVP、MVVM、VIPER架构

    在 iOS 中使用 MVC 架构感觉很奇怪? 迁移到MVVM架构又怀有疑虑?听说过 VIPER 又不确定是否真的值得切换? 相信你会找到以上问题的答案,如果没找到请在评论中指出. 你将要整理出你在 i ...

随机推荐

  1. 如何安装和配置RabbitMQ(转载)

    如何安装和配置RabbitMQ 今天开始一个小小的练习,学习一下安装和配置RabbitMQ,为什么要学它,因为WCF可以完全兼容和使用RabbitMQ了.我们新的大数据系统需要使用消息队列,所以就开始 ...

  2. 新版openvpn for pc使用旧证书问题的处理

    在client.ovpn中增加一句: tls-cipher "DEFAULT:@SECLEVEL=0"

  3. Delphi 透明窗体显示文字

    设置窗体属性:BorderStyle 属性设置为 bsNoneColor 属性设置为 clWhite(白色:窗体背景色)TransparentColor 属性设置为 trueTransparentCo ...

  4. Mysql 6.0安装过程(截图放不上去)

      由于免费,MySQL数据库在项目中用的越来越广泛,而且它的安全性能也特别高,不亚于oracle这样的大型数据库软件.可以简单的说,在一些中小型的项目中,使用MySQL ,PostgreSQL是最佳 ...

  5. numpy-帮助文档 & 速查表.md

    目录 转相关资料: 速查表 速查代码 转相关资料: 官方手册 易佰教程 gitbook ZMonster's Blog 速查表 速查代码 # -*- coding: utf-8 -*- "& ...

  6. 16.1 用auth0服务 实现用登录和管理 使用auth版本的2个大坑。

    这是三周内容,实现用户登录和管理 回到master分支 切换到 han分支 更新一下 然后工作 开始工作写代码了 安装2个angular端的auth0的lib,也可不安装,后边有不安装的做法 不安装的 ...

  7. FMS Dev Guide学习笔记

    翻译一下其中或许对游戏开发有用的一个章节 一.开发交互式的媒体应用程序 1.共享对象(Shared objects)     ----关于共享对象     使用共享对象可以同步用户和存储数据.共享对象 ...

  8. mysql 数据库必备命令操作,入门练习一下

    mysql 数据库必备命令操作 show databases: 查看所有的数据库: create database jfedu: 创建名为jfedu数据库: use nihao: 进入jfedu数据库 ...

  9. Winform 各种属性、方法、控件

    窗体是程序与用户交互的可视界面,窗体也是对象,窗体类定义了生成窗体的模版,实例化一个窗体类就产生了一个窗体. .NET框架类库的System.Windows.Forms命名空间中定义的Form类是所有 ...

  10. 10.18号java课后动手动脑

    问题一结论:类如果提供了一个自定义的构造方法,将导致系统不再提供默认构造方法. 问题二结论:(1)程序运行的结果是100和300,field=200为类的初始化块,可以在类中使用“{”和“}”将语句包 ...