`
tubaluer
  • 浏览: 1500063 次
文章分类
社区版块
存档分类
最新评论
  • sblig: c / c++ 是不一样的都会输出 100
    j = j++

三层架构与MVC谜团之答案揭晓

 
阅读更多
    我们平时总是将三层架构与MVC混为一谈,殊不知它俩并不是一个概念。下面我来为大家揭晓我所知道的一些真相。

首先,它俩根本不是一个概念。

    
    三层架构是一个分层式的软件体系架构设计,它可适用于任何一个项目。
    MVC是一个设计模式,它是根据项目的具体需求来决定是否适用于该项目。
    那么架构跟设计模式有什么区别呢?
    我们从接手一个项目开始,首先,我们需要进行架构设计,一般我们采用的就是分层式的架构设计,即我们的三层架构。
    然后,在确定了架构以后,我们再根据项目的具体需求去考虑是否需要应用一些设计模式,比如是否应用我们的MVC模式,抽象工厂模式等等。(在这里我们看出,MVC与三层架构不是一个等级的,而与抽象工厂等设计模式才是一路的)
    最后,确定了模式以后,就是我们的一些具体的实现了。(当然一个项目不仅仅考虑这些问题,我只是为了说明两者的区别,将其他问题已省略)
其次,它俩划分的层次不同。
    三层架构将整个项目划分为:表现层(UI)、业务逻辑层(BLL)、数据访问层(DAL)。
    MVC即Model(模型),View(视图),Controller(控制)。
    下面看一下他俩的区别与联系:
    通过这个图我们可以知道,我们平常所说的V是UI,C是BLL,M是DAL的观点是错误的。
而我们通常所见到的MVC一般也都是在应用三层架构的基础上,即将Model层再进行分层。而如果Model不再进行划分的话,那么使用MVC的意义也就不大了。
 
然后,它俩的目的着重点不同。
    三层架构的目的着重点是“高内聚,低耦合”,即解耦。
    MVC的目的则是实现Web系统的职能分工,即职责划分。
    其实职责划分也是解耦,但是三层侧重的是整体的一个解耦,而MVC侧重的是web系统的解耦,即侧重jsp和Servlet的一个解耦。
最后,为何我们会将其混为一谈?
    既然两者有这么多的不同,我们为什么还总是将其混淆呢,下面我列举了几个我们常常将其混为一谈的几个原因:
    1.二者都是“三层”。
    这个原因是最容易迷惑我们初学者的,一个是UI,BLL,DAL,一个是View,Controller,Model,不都是三层吗?
    虽然都是“三层”(不一定是真的三层,还可以是多层),但是它们的划分的不一样。大家可从上面的图中看出不同。
    2.MVC总是伴随着三层架构
    这个就是我在前面一再强调的,我们一般是在考虑使用(也可以不使用)了三层架构的基础上再根据具体需求决定是否需要使用MVC,于是我们常说的MVC中总是伴随着三层架构,所以大家总是会认为MVC就是三层架构,三层架构就是MVC,殊不知,它们二者是一起出现的。
    3.都是在分层,即都是在解耦。
前面说它们目的的时候也说了,虽然它们的侧重点不同,但是它们的总体目的是一样的,都是为了解耦,对于初学者而言,是不知道这两个侧重点有何不同的。
    大家往往对它们的联系知道很多,不然也不会混为一谈,但是对它们的区别却知道较少,希望我上面讲解的它们两者之间的区别可以让大家对它们有些了解,如有写的不妥的地方,请指教。
分享到:
评论

相关推荐

    C#三层架构的MVC项目源码

    本程序一个基于三层架构的MVC模式应用的完整示例项目源码,基于Asp.net 3.5开发, 结构更简洁,提供更多有效的示例源码参考。 方便用户更好的理解和使用该架构进行开发,配合动软.Net代码生成器,可以使开发效率...

    UML图设计模式、三层架构、MVC.EAP

    UML图设计模式、三层架构、MVC.EAP

    MVC三层架构

    MVC三层架构基础介绍简单来说,Design Patten 就是一个常用的方案。 在我们的开发过程中,经常会遇到一些相同或者相近的问题,每次我们都会去寻找一个新的解决方法,为了节省时间提高效率,我们提供一些能够解决这些...

    三层架构和MVC模式区别

    三层架构与MVC模式在软件开发领域中是两种常见的设计思想,它们各自有着独特的应用场景和优势,但在实际项目中往往容易被混淆。本文旨在深入解析三层架构与MVC模式的区别,帮助开发者更好地理解和运用这两种模式。 ...

    三层架构与MVC.pdf

    【三层架构】 三层架构是一种常见的软件开发模式,旨在实现...总结来说,三层架构和MVC模式是软件设计中的重要工具,它们有助于构建可维护、可扩展的系统。理解并灵活运用这些设计模式,可以提升开发效率和软件质量。

    ASP.NET MVC 三层架构与mvc实例

    总结来说,"ASP.NET MVC 三层架构与mvc实例"是一个结合了ASP.NET MVC框架和三层架构思想的BBS系统开发示例,利用这种架构,开发者可以清晰地组织代码,实现数据库操作,同时通过Ajax技术优化用户界面。通过学习这个...

    三层架构和MVC的区别和联系

    综上所述,三层架构强调的是软件系统中不同功能模块的分离与组织,而MVC模式侧重于组件间的通信和协作。在具体的项目开发中,MVC模式常常被用于实现三层架构中的业务逻辑层和表示层的功能。通过了解和掌握这两种模型...

    AMX三层架构(MVC)家庭财务管理系统源码

    AMX三层架构(MVC)家庭财务管理系统源码 源码描述: 家庭财务管理系统: 典型的MVC三层架构编写,代码层次清晰,是学习三层架构以及工厂模式,反射的轻量级DEMO学习实例。 主要功能包含: 1、财务项目管理、家庭...

    一个三层架构的MVC代码

    三层架构和MVC模式是软件开发中的两种重要设计模式,它们在构建大型、可维护的Web应用程序时尤其有用。在这个名为“MVCDemo2”的项目中,我们可以看到这两种模式的结合应用。 首先,三层架构是一种将业务逻辑、数据...

    MVC模式与三层架构区别

    ### MVC模式与三层架构区别详解 #### 一、引言 在软件开发过程中,合理的设计模式和架构能够显著提升系统的可维护性和扩展性。本文旨在深入解析MVC(Model-View-Controller)模式与三层架构(3-tier architecture...

    MVC+三层架构+EF的增删改查操作(连接数据库的).rar

    在提供的示例中,"MVC+三层架构+EF的增删改查操作(连接数据库的)"是一个实际的应用程序演示,它结合了MVC模式和三层架构,用于展示如何使用ASP.NET MVC、三层架构和Entity Framework进行数据库操作。这个demo可能...

    MVC 三层架构示例

    MVC架构将应用程序分为三个主要部分:模型(Model)、视图(View)和控制器(Controller),以此实现良好的代码组织和职责分离,提高系统的可维护性和可扩展性。 1. **模型(Model)**:模型是应用程序的核心,负责...

    MVC与三层架构

    1. **关注点分离程度**:三层架构更加侧重于将业务逻辑与数据访问完全分离,而MVC架构则侧重于分离视图、控制器和模型,但业务逻辑往往被包含在模型或控制器中。 2. **灵活性**:MVC架构由于其清晰的分层,更易于...

    三层结构与MVC

    通过对比三层架构与MVC架构,我们可以发现它们各有优势和局限性。选择哪种架构取决于项目的具体需求和技术团队的能力。在实际开发过程中,结合两者的优势,可以构建出既灵活又高效的系统。例如,在Web开发中,可以...

    基于ASP.NET和SQLServer的酒店管理系统-采用三层架构与MVC框架,附带图片轮播与好友板功能,适合基础学习和交流参考源码 ,C#-asp.net酒店管理系统,三层架构 基于asp.net

    基于ASP.NET和SQLServer的酒店管理系统——采用三层架构与MVC框架,附带图片轮播与好友板功能,适合基础学习和交流参考源码。,C#_asp.net酒店管理系统,三层架构 基于asp.net,sqlserver开发的酒店管理系统,采用三...

    C#MVC 三层架构 ,清晰明了 bootsrap

    【C# MVC 三层架构详解】 C# MVC(Model-View-Controller)是一种设计模式,广泛应用于.NET框架下的Web应用程序开发。它将应用程序分为三个主要部分:模型(Model)、视图(View)和控制器(Controller),以实现...

    asp.net MVC三层架构

    Model(模型)是应用程序中用于处理应用程序数据逻辑的部分。 通常模型对象负责在数据库中存取数据。 View(视图)是应用程序中处理数据显示的部分。...这个适合刚接触三层架构的来学习,比较简单。

    C#本科期末大作业MVC三层架构亮灯的仓库管理系统源码.zip

    C#本科期末大作业MVC三层架构亮灯的仓库管理系统源码。MVC+MYSQL+EasyuiC#本科期末大作业MVC三层架构亮灯的仓库管理系统源码。MVC+MYSQL+EasyuiC#本科期末大作业MVC三层架构亮灯的仓库管理系统源码。MVC+MYSQL+...

Global site tag (gtag.js) - Google Analytics