zoukankan      html  css  js  c++  java
  • 三层结构与MVC

      实验室学弟突然又谈到了三层结构与MVC的话题,想想还是有必要整理一下这些个基本概念,且也纠正自己之前对二者的概念混淆,乃至将其错误思想指导于开发中。

      关键词:三层结构(三层架构)MVC框架(思想)基于J2EE/BS软件结构的三层架构Service/Model/Controller三者的区别

      立场:三层结构绝不等同于MVC,二者的思想不相同!!!但从代码与程序的物理逻辑构件组织的角度来看,会有一定的联系。

    一、三层结构(3-Tier Architecture)

      1. 目的:为了服从“高内聚低耦合”的思想,模块化的软件工程思想,是基于分层架构下的一种常用的分层架构模式的一种

      2.优点:降低层与层之间的依赖、标准化。

    1、开发人员可以只关注整个结构中的其中某一层;
    2、可以很容易的用新的实现来替换原有层次的实现;
    3、可以降低层与层之间的依赖;
    4、有利于标准化;
    5、利于各层逻辑的复用。
    6、结构更加的明确
    7、在后期维护的时候,极大地降低了维护成本和维护时间

      3.缺点:系统架构复杂,不适合小型项目。

    1、降低了系统的性能。这是不言而喻的。如果不采用分层式结构,很多业务可以直接造访数据库,以此获取相应的数据,如今却必须通过中间层来完成。
    2、有时会导致级联的修改。这种修改尤其体现在自上而下的方向。如果在表示层中需要增加一个功能,为保证其设计符合分层式结构,可能需要在相应的业务逻辑层和数据访问层中都增加相应的代码。
    3、增加了开发成本。

      4.定位:最经典/最常见的软件体系架构设计中的一种。常见的其他软件架构设计还有:分层模式(含:三层结构)、客户端-服务器模式、主从设备模式、管道-过滤器模式、代理模式、点对点模式、事件总线模式、模型-视图-控制器(MVC)模式、黑板模式、解释器模式。

      5.哪三层?分层式结构一般分为三层,从下至上分别为:数据访问层(Data Access Layer)业务逻辑层(Business Logic Layer,又或称为领域层,Domain)、表示层(又称为界面层,User Interface Layer)。这里所说的三层体系,不是指物理上的三层,不是简单地放置三台机器就是三层体系结构,也不仅仅有B/S应用才是三层体系结构,三层是指逻辑上的三层,即把这三个层放置到一台机器上。

     

    [图片来源于 百度]

      三层体系的应用程序将业务规则、数据访问、合法性校验等工作放到了中间层进行处理。

      6.数据访问层主要看数据层里面有没有包含逻辑处理,实际上它的各个函数主要完成各个对数据文件的操作。而不必管其他操作。主要是对非原始数据(数据库或者文本文件等存放数据的形式)的操作层,而不是指原始数据,也就是说,是对数据库的操作,而不是数据,具体为业务逻辑层或表示层提供数据服务。

      7.业务逻辑层主要负责对数据层的操作。也就是说把一些数据层的操作进行组合。主要是针对具体的问题的操作,也可以理解成对数据层的操作,对数据业务逻辑处理,如果说数据层是积木,那逻辑层就是对这些积木的搭建。

      8.界面层主要对用户的请求接受,以及数据的返回,为客户端提供应用程序的访问。主要表示WEB方式,也可以表示成WINFORM方式,WEB方式也可以表现成:aspx、jsp,如果逻辑层相当强大和完善,无论表现层如何定义和更改,逻辑层都能完善地提供服务。用于显示数据和接收用户输入的数据,为用户提供一种交互式操作的界面。

     

    二、MVC框架(Model View Controller)

      1.定义:MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计模式的典范,用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。MVC被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构中。

      2.简介:

      ①MVC开始是存在于桌面程序中的,M是指业务模型,V是指用户界面,C则是控制器,使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式。比如一批统计数据可以分别用柱状图、饼图来表示。C存在的目的则是确保M和V的同步,一旦M改变,V应该同步更新。

      ②MVC指MVC模式的某种框架,它强制性的使应用程序的输入、处理和输出分开。使用MVC应用程序被分成三个核心部件:模型、视图、控制器。它们各自处理自己的任务。最典型的MVC就是JSP(View) + Servlet(Controller) + JavaBean(Model)的模式。

    [基于Struct2的MVC设计]

      设想Java Web(B/S架构+前后端分离):

        Model:将处理结果全部封装于会话、响应中,部分处理以抛出异常形式,交由最上层(渲染到用户视图)处理(异常)。

          异常渲染层:处理下层抛出的异常,调度页面或者输出JSON。

      3.MVC

      Model(模型)表示应用程序中用于处理应用程序数据逻辑的部分。 通常模型对象负责在数据库中存取数据。

      View(视图)表示应用程序中处理数据显示的部分。 通常视图是依据模型数据创建的。

      Controller(控制器)处理输入(写入数据库记录),是应用程序中处理用户交互的部分。 通常控制器负责从视图读取数据,控制用户输入,并向模型发送数据。

      

    [图片来源 百度]

    实践过程中,每个人对MVC的理解不同,其实现方式与软件的设计也就会不同了,无统一严格的实践标准,尤其是在M、V、C三者之间的通讯关系,可谓是百花齐放。

    附:

    实际上它们完全是不同的概念。

    框架、设计模式这两个概念总容易被混淆,其实它们之间还是有区别的。框架通常是代码重用,而设计模式是设计重用,架构则介于两者之间,部分代码重用,部分设计重用,有时分析也可重用。在软件生产中有三种级别的重用:内部重用,即在同一应用中能公共使用的抽象块;代码重用,即将通用模块组合成库或工具集,以便在多个应用和领域都能使用;应用框架的重用,即为专用领域提供通用的或现成的基础结构,以获得最高级别的重用性。

     

    三、小结

      重申立场:三层结构绝不等同于MVC,二者的指导思想不相同!!!但从代码与程序的物理逻辑构件组织的角度来看,会有一定的联系。

      MVC中的Model可以类似看做三层结构中的业务逻辑层(不完全是Model)+数据访问层;

      MVC中的View可以类似看做三层结构中的UI层(不完全是View)。

      而Controller绝不可以等效于三层结构中的任一层。

     

    MVC模式与三层架构联系:

    ui (view)←(contorller)

    ***********************

    bll  (model)

    ***********************

    dal (model)

     

         View-UI Layer  |   Controller-Bussiness Layer  |  Model-Data Access Layer 其实这样是错误的 。

      MVC是表现模式(Presentation Pattern); 三层架构是典型的架构模式(Architecture Pattern)。

      三层架构的分层模式是典型的上下关系,上层依赖于下层。但MVC作为表现模式是不存在上下关系的,而是相互协作关系。

      即使将MVC当作架构模式,也不是分层模式。MVC和三层架构基本没有可比性,是应用于不同领域的技术。

      [有待经过时间的洗礼,再作校正]

       

    四、参考文献

      1.【10种常见的软件架构模式 - 博客园】https://www.cnblogs.com/IcanFixIt/p/7518146.html

      2.【三层结构 - 百度百科】https://baike.baidu.com/item/三层架构/11031448?fr=aladdin

      3.【MVC - 百度百科】https://baike.baidu.com/item/MVC框架?fromtitle=mvc&fromid=85990

      4.【MVC模式与三层架构的区别 - 博客园】https://www.cnblogs.com/yourshj/p/5197310.html

      5.【MVC中 model view controller 关系 - 博客园】https://www.cnblogs.com/baimangguo/p/6554351.html

      6.【struct2与MVC及环境搭建】https://blog.csdn.net/linerzong/article/details/8656250

  • 相关阅读:
    大话设计模式(二)代理模式 工厂方法模式 原型模式 模板方法模式 迪米特法模式 外观模式
    大话设计模式(一)简单工厂模式 策略模式 单一职责原则 开放-封闭原则 依赖倒置原则 装饰模式
    eclipse为hibernate.cfg.xml添加自动提示【转】
    Caused by: java.lang.NoSuchMethodError: javax.persistence.spi.PersistenceUnitInfo.getValidationMode
    Chrome 浏览器提示adobe flash player不是最新版本
    spring mvc <mvc:default-servlet-handler /> 。
    S2SH CRUD 整合
    Ms sql行转列。汇总
    Hibernate中的数据库方言(Dialect)
    SSH整合(1)异常
  • 原文地址:https://www.cnblogs.com/johnnyzen/p/9198072.html
Copyright © 2011-2022 走看看