首页 > 代码库 > 浅谈MVC
浅谈MVC
一、MVC的产生之源
MVC是Model、View、Controller这三个英文单词的缩写,从这三个单词的含义中我们可以看出MVC的核心是什么?显而易见,Model指的是模型,在某些地方你也可以理解为数据,自我接触MVC到现在,Model所扮演的角色就是数据实体;View指的是视图,也就是与用户进行交互的界面;Controller指的是控制器,那么它控制的是什么呢?在网上Controller的作用就是负责业务逻辑处理,通俗的讲,就是处理视图与数据之间的逻辑处理,它只是接受请求,决定调用哪个模型来处理请求,然后再确定用哪个视图来显示返回的数据。在MVC没有提出之前,可能Model和View交缠在一起,难以区分,Controller的产生可能就是为了解决这一问题吧。
二、Java Swing
Swing号称是完全按照MVC的思路来进行设计的。但是严格的说,Swing中的MVC实际上是MVC的一个变体:M-VC。 Swing中只显示的定义了Model接口,而在一个UI对象中集成了视图和控制器的部分机制。View和Control比较松散的交叉组合在一起,而更多的控制逻辑是在事件监听者部分引入的。
在Swing中基本上每一个组件都会有对应的Model对象。但其并不是一一对应的,一个Model接口可以为多个Swing对向服务,例如:JProgressBar,JScrollBar,JSlider这三个组件使用的都是BoundedRangeModel接口。这种模型的共享更能够充分的体现MVC的内涵。除了Model接口外,为了实现多个视感间的自由切换,每个Swing组件还包含一个UI接口,也就是View-Controller,负责对组件的绘制和接受用户输入。
Model-View是Subject和Obverser的关系,因而,模型的改变必须要在UI对象中体现出来。Swing使用了JavaBeans的事件模型来实现这种通知机制。具体而言,有两种实现办法,一是仅仅通知事件监听者状态改变了,然后由事件监听者向模型提取必要的状态信息。这种机制对于事件频繁的组件很有效。另外的一种办法是模型向监听者发送包含了已改变的状态信息的通知给UI。这两种方法根据其优劣被分别是现在不同的组件中。比如在JScollBar中使用的是第一种方法,在JTable中使用的是第二种方法。而对Model而言,为了能够支持多个View,它并不知道具体的每一个View。它维护一个对其数据感兴趣的Obverser的列表,使得当数据改变的时候,能够通知到每一个Swing组件对象。
三、J2EE
在J2EE中,SUN公司把MVC的理念提升到一个新的高度,这里的MVC的含义就更为广泛了,就是我们最开始接触MVC时所用的JSP+JavaBean+Servlet开发模式。相较于上面的Swing,大家对J2EE应该更加了解。JSP能够生成HTML,WML甚至XML,它对应于Web应用程序中的View部分;JavaBean可以分为业务逻辑层和数据持久层,JavaBean的数据持久层对应与Web应用程序中的Model部分;而JavaBean的业务逻辑层或者Servlet对应于Web引用程序中的Controller部分,两种类型的Controller各有其优缺点:JSP同Servlet的交互不容易规范化,使得交互的过程变得复杂,但是Servlet可以单独同用户交互,实际上JSP的运行时状态就是Servlet;而由于JavaBean的规范性,JSP同JavaBean的交互很容易,利用JavaBean的get/set方法,JSP不需要过多的语句就可以完成数据的存取,这能够让JSP最大限度的集中在其视图功能上,而且,在桌面应用程序中使用JavaBean也很容易,而用Servlet就相对麻烦许多。根据不同的问题背景,可以选取不同的Controller,有时候也可以两者混合使用,或者直接在Servlet中调用JavaBean。
四、SSH
MVC是一种框架模式,是一种思想,SSH是一种框架,是框架模式的实现,SSH是一种经典的MVC模式。
其中使用Struts作为系统的整体基础架构,负责MVC的分离,在Struts框架的模型部分,控制业务跳转,利用Hibernate框架对持久层提供支持,Spring做管理,管理struts和hibernate。具体做法是:利用Hibernate将模型实现为基本的Java对象,然后编写基本的DAO接口,并给出Hibernate的DAO实现,采用Hibernate架构实现的DAO类来实现Java类与数据库之间的转换和访问,最后由Spring做管理,管理struts和hibernate。
浅谈MVC