MVC心得

    前言

         先说前提:不同的平台和不同的语言框架对MVC的定义各有不同,并没有一个明确的定义。MVC的存在是为了让复杂的软件有清晰合理的架构,使其便于开发和维护。但请注意,MVC模式中的每个部分是分工明确、界定清晰的。

可以看到内部之间的交互有不同实现方式存在,实际实现要落在具体的平台及语言。


介绍

         我想以一种概括式的描述来介绍一下MVC。

      MVC(模型(Model)-视图(View)-控制器(Controller)):

         Model(模型)是应用程序中用于处理应用程序数据逻辑的部分。

                  通常模型对象负责在数据库中存取数据。

         View(视图)是应用程序中处理数据显示的部分。

                  通常视图是依据模型数据创建的。

         Controller(控制器)是应用程序中处理用户交互的部分。

                   通常控制器负责从视图读取数据,控制用户输入,并向模型发送数据。

 

      用户(USER)

         对MVC言,我认为在介绍的的时候也需要提到用户这一角色。因为当我查阅资料时,用户(USER)在与MVC的交互部分在实际中也是可以有不同实现方式存在。


      意义

           耦合性低

         MVC是一个框架模式,它强制性的使应用程序的输入、处理和输出分开。

         使复杂的软件有清晰合理的架构,视图层和业务层分离,这样就允许更改视图层代码而不用重新编译模型和控制器代码,同样,一个应用的业务流程或者业务规则的改变只需要改动MVC的模型层即可。因为模型与控制器和视图相分离,所以很容易改变应用程序的数据层和业务规则。

           重用性高

         MVC模式允许使用各种不同样式的视图来访问同一个服务器端的代码,因为多个视图能共享一个模型。由于模型返回的数据没有进行格式化,所以同样的构件能被不同的界面使用。由于已经将数据和业务规则从表示层分开,所以可以最大化的重用代码了。

           生命周期成本低

         MVC使开发和维护用户接口的技术含量降低。

           部署快

         使用MVC模式使开发时间得到相当大的缩减,它使程序员(Java开发人员)集中精力于业务逻辑,界面程序员(HTML和JSP开发人员)集中精力于表现形式上。

           可维护性高

         分离视图层和业务逻辑层也使得WEB应用更易于维护和修改。

           有利软件工程化管理

         由于不同的层各司其职,每一层不同的应用具有某些相同的特征,有利于通过工程化、工具化管理程序代码。控制器也提供了一个好处,就是可以使用控制器来联接不同的模型和视图去完成用户的需求,这样控制器可以为构造应用程序提供强有力的手段。给定一些可重用的模型和视图,控制器可以根据用户的需求选择模型进行处理,然后选择视图将处理结果显示给用户。

 

      缺点

           没有明确的定义

         完全理解MVC并不是很容易。使用MVC需要精心的计划,由于它的内部原理比较复杂,所以需要花费一些时间去思考。同时由于模型和视图要严格的分离,这样也给调试应用程序带来了一定的困难。每个构件在使用之前都需要经过彻底的测试。

           不适合小型,中等规模的应用程序

         花费大量时间将MVC应用到规模并不是很大的应用程序通常会得不偿失。

           增加系统结构和实现的复杂性

         对于简单的界面,严格遵循MVC,使模型、视图与控制器分离,会增加结构的复杂性,并可能产生过多的更新操作,降低运行效率。

           视图与控制器间的过于紧密的连接

         视图与控制器是相互分离,但却是联系紧密的部件,视图没有控制器的存在,其应用是很有限的,反之亦然,这样就妨碍了他们的独立重用。

           视图对模型数据的低效率访问

         依据模型操作接口的不同,视图可能需要多次调用才能获得足够的显示数据。对未变化数据的不必要的频繁访问,也将损害操作性能。

           一般高级的界面工具或构造器不支持模式

         改造这些工具以适应MVC需要和建立分离的部件的代价是很高的,会造成MVC使用的困难。

原文地址:https://www.cnblogs.com/Sherlock-J/p/12926046.html