MVC 即 Model View Controller 。mvc是一种很好的设计模式的综合应用。其中
M 即Model(模型层),主要负责处理业务逻辑以及与数据库的交互。
V 即View(视图层),主要用于显示数据和提交数据。
C 即Controller(控制器),主要用于接受请求并控制请求转发。
三层架构,是最基本的项目分层结果。秉承“高内聚,低耦合”的思想,将整个业务应用划分为:UI层(表示层)、BLL(业务逻辑层)、DAL层(数据访问层)。系统的主要功能和业务逻辑在BLL层进行处理。
UI:表示层,也叫做用户界面层,用来接受用户的请求,以及数据返回。。可以是WEB、也可以是WinForm。
BLL:业务逻辑层,主要负责对数据层的操作,对数据业务逻辑的处理。
DAL:数据访问层,直接操作数据库,包括增、删、改、查、备份、还原等操作。
从二者的区别,我没有在网上找到一个定论,主要观点以下有几个:
① MVC是一种复合设计模式,而三层是一个软件架构。
软件架构是用接口来实现的,而设计模式则是一种设计思想、设计理念的升华,也可以算做一种解决方案。一个系统一般只有一个软件架构,而可以有多个设计模式,因为设计模式是可以复用的。
② 在三层架构中没有定义Controller的概念,而MVC中也没有将业务的逻辑访问看成两个层。当然了。在三层中也提到了Model,但是三层架构中Model(Entry)的概念与MVC中Model的概念是不一样的,“三层”中典型的Model层是以实体类构成的,而MVC里,则是由业务逻辑与访问数据组成的。
③三层结构模式又可归于部署模式,MVC可归于表示模式。
④三层架构划分为:View(UI)、BIZ(BLL)、ADO(DAL)、Entity(Model)、Controller。而MVC把
BIZ(BLL)、ADO(DAL)、Model(Entity) 统一称之为 模型(MODEL),得到:View、Controller、模型(MODEL) 三层。
我认为,二者并不是互斥的,相反,MVC和多层应用软件结构有着异曲同工之妙,而且可以相互结合进行开发。MVC中的每一个环节都可以采用多层应用软件结构进行设计。而多层应用软件中的每一层又可以采取MVC来进行设计。所以说可以是:M层对应于BLL和DAL。V对应于UI,而C则对应于层与层之间的联系。也可以M对应于DAL,C对应于BLL,而V仍然对应于UI。