首页 > 代码库 > 【Java架构学习】Model1和Model2讨论

【Java架构学习】Model1和Model2讨论

    在Java的学习中,这两个词的频率出现的很高,那就是Model1和Model2。那么究竟什么是Model1,什么是Model2呢?我们是不是又很自然接受这两个概念,但是不知道其所以然呢?今天我们就来好好讨论一下,何为Model1,何为Model2,它们二者之间又有什么区别呢?

    在正式开始之前,我想说一点题外话。我发现我们的学习有时候会陷入这样一种境地,比如说出现一个新概念,我们会非常自然的接受,然后不问所以然的就那么去用。被问及为什么这样写这样用的时候?“不知道,我最开始学的时候就是这样学的,所以这么用”。

    比如最开始学习编程的时候,我们知道要new对象,用对象去调方法。可是就是这个new的过程,我们真的懂吗?举个例子,要new一个user用户,我们会这样写:User user = new User()  都知道这么写,都知道这样能new出user对象,然后用这个对象去调方法就可以了,就是很固化的一种思维习惯让你去适应,知道“哦,我这么写就能得出我想要的东西”,可是为什么这么写,这个new是什么意思想过吗?而这种误区会在后面的学习中越来越残酷的显露出来。就是想当然所以然的去接受,然后不加思考的去固化使用,这似乎是我们普遍存在的问题,最起码,在我身上得到了很好的体现。

    要知道,我们在学习之初可以得过且过,但是有句话,我师傅说的,当一个东西出现第一遍的时候,你可以放过它;出现第二遍的时候你也可以放过他,出现第三遍的时候你可能看着不仅眼熟而且有必要好好研究它了。所以较之以前很自然的接受,现在我们也来挖挖Model1和Model2的老底。

    我之所以把MVC放在前面一篇文章写出来,是因为这篇文章跟MVC是有联系的,这个我们后面再说。今天这篇文章我们就好好把Model1和Model2研究明白,把它们二者的区别分析好,以便于更好的吸收后面的内容。

    下面这个是Model1的时序图,重点要了解它的调用流程和它由几部分组成。

    这个是Model2的时序图。这个跟Model1一比较,Model1就显得很逊了有没有?

    要把Model1和Model2了解清楚,就不得不把MVC揪出来。随着学习的深入,我们发现:

    Model1相当于JSP+JavaBean;

    Model2相当于JSP+Servlet+JavaBean;

   可能有人会问了,JavaBean是什么啊?JavaBean在MVC设计模型中是模型层,即Model,是用来设置数据的属性和行为的,然后提供获取属性和设置属性的get/set方法。所以你再看上面两张图的时候,是不是觉得熟悉了很多?

    所以对于Model1而言,它的模式相当于JSP+JavaBean,它把业务逻辑也放到视图里面,相对于MVC而言,Model1仅包含M和V。从整个调用流程而言,JSP获取表单数据并提交,调用业务逻辑进行处理,处理完毕之后返回给JSP,JSP显示给用户。Model1是以JSP为中心附加的JavaBean,这种开发模式让所有的业务逻辑和界面显示都依赖于JSP,数据整理靠JavaBean完成。这样很不安全,而且不好维护。所以Model适合小型项目开发。

    而对于Model2来说它是MVC的开发模式。其实Model1也一定程度上实现了MVC,即JSP将控制层和显示层合二为一了,JavaBean为模型层;而Model2呢则把控制层Servlet单独划分出来了,专门负责业务流程的控制,接受页面请求,创建所需的JavaBean实例,并将处理后的数据返回给JSP。所以对整个调用流程而言:Servlet获取表单数据并提交,调用业务逻辑进行处理,把处理完毕的数据返回给Servlet,Servlet再调用JSP传递参数,最后JSP将结果显示给用户。所以对Model2而言适合大型的项目开发.

    Model1和Model2是SUN公司对于MVC模式所先后推出的两种规范,其实没有孰优孰劣之分,只是在不同的时期为了适应不同的项目需求所做的调整。有的项目适合用Model1做,用Model2反而显得笨拙;有的项目Model1做就不如Model2来的得心应手。生活也是一样,每个人都有各自的特长,各自的不足,不必懊悔更不必比较出输赢,正确的认识自己,在合适的人生“大项目”展现出自己的一技之长,才是我们真正该认识到的。

 

 

 

 

【Java架构学习】Model1和Model2讨论