三层架构(3-tier application) 一般意义上的三层架构就是将整个业务应用划分为:表现层(UI)、业务逻辑层(BLL)、数据访问层(DAL)。区分层次的目的即为了“高内聚,低耦合”的思想。web
一、表现层(UI):通俗讲就是展示给用户的界面,即用户在使用一个系统的时候他的所见所得。 数据库
二、业务逻辑层(BLL):针对具体问题的操做,也能够说是对数据层的操做,对数据业务逻辑处理。 设计模式
三、数据访问层(DAL):该层所作事务直接操做数据库,针对数据的增添、删除、修改、更新、查找等。 架构
表现层实现的表明做品是Struts框架,业务层实现的表明做品是Spring,持久层实现的表明做品是Hibernate。 mvc
举个例子:app
持久层从持久库中取出-10。框架
业务层按照必定的逻辑(这里咱们举例取温度的逻辑)翻译成-10摄氏度。dom
表示层显现给用户“哎呀,今天好冷!”。spa
层就至关于一个黑盒子,咱们不用知道它内部怎么实现,只须要知道如何去调用它就好了。每层只与上下相邻的两层打交道。当一层内部因为技术变迁发生变化时,只要接口不变,其余层不用作任何改变。分层以后灵活性提升,也便于团队分工开发。翻译
Model(模型):数据模型,提供要展现的数据,所以包含数据和行为,能够认为是领域模型(domain)或JavaBean组件(包含数据和行为),不过如今通常都分离开来:Value Object(数据) 和 服务层(行为)。也就是模型提供了模型数据查询和模型数据的状态更新等功能,包括数据和业务。
View(视图):负责进行模型的展现,通常就是咱们见到的用户界面,客户想看到的东西。
Controller(控制器):接收用户请求,委托给模型进行处理(状态改变),处理完毕后把返回的模型数据返回给视图,由视图负责展现。 也就是说控制器作了个调度员的工做。
从图中咱们还看到,在标准的MVC中模型能主动推数据给视图进行更新(观察者设计模式,在模型上注册视图,当模型更新时自动更新视图),但在Web开发中模型是没法主动推给视图(没法主动更新用户界面),由于在Web开发是请求-响应模型。
Web MVC中的M(模型)-V(视图)-C(控制器)概念和标准MVC概念同样,咱们再看一下Web MVC标准架构,以下图所示:
在Web MVC模式下,模型没法主动推数据给视图,若是用户想要视图更新,须要再发送一次请求(即请求-响应模型)。
M:(Model) 模型 : 应用程序的核心功能,管理这个模块中用的数据和值;
V(View )视图: 视图提供模型的展现,管理模型如何显示给用户,它是应用程序的外观;
C(Controller)控制器: 对用户的输入作出反应,管理用户和视图的交互,是链接模型和视图的枢纽。
MVC用于将web(UI)层进行职责解耦
MVC是 Model-View-Controller,严格说这三个加起来之后才是三层架构中的UI层,也就是说,MVC把三层架构中的UI层再度进行了分化,分红了控制器、视图、实体三个部分,控制器完成页面逻辑,经过实体来与界面层完成通话;而C层直接与三层中的BLL进行对话。
MVC能够是三层中的一个表现层框架,属于表现层。三层和mvc能够共存。
三层是基于业务逻辑来分的,而MVC是基于页面来分的。
MVC主要用于表现层,3层主要用于体系架构,3层通常是表现层、中间层、数据层,其中表现层又能够分红M、V、C,(Model View Controller)模型-视图-控制器
MVC是表现模式(Presentation Pattern)
三层架构是典型的架构模式(Architecture Pattern)
三层架构的分层模式是典型的上下关系,上层依赖于下层。但MVC做为表现模式是不存在上下关系的,而是相互协做关系。即便将MVC看成架构模式,也不是分层模式。MVC和三层架构基本没有可比性,是应用于不一样领域的技术。