• MVC你是怎样理解的?


     近期的学术交流会议都在研究MVC,秉着好好学习,天天向上的心理,时不时的就去蹭会。说实话,原来也有看过MVC的一些相关资料,可是仅仅是浅尝辄止。并且,由于先学了三层,所以再看MVC的时候,潜意识里的就觉得它们是一个东西。可是MVC是MVC,三层是三层。以下就将昨晚学术交流会议讨论的结果以及讨论方式展现给大家。 如有不足之处,还望批评指正!


    三层划分为U(界面层)、B(业务逻辑层)、D(数据訪问层),这是我们最先接触过的分层思想。在学了三层之后,我们又接触到了MVC ,这时候我们自然而然的会拿MVC与三层来做比較。可是比較之后,出现了以下的两种结果,下图所看到的:


         

    错误观点一:

             有部分人直接把三层的U层等同于MVC的View + Controller。 BLL层 + DAL层 等同于 Model。 


    正确观点一:

             BLL层中包括两部分:一是IBLL,即抽象出来接口部分,定义了要做什么?二是BLL,即详细实现部分,定义怎么做?而Controller是控制器的意思,它负责的是转发到哪个视图和指挥要干什么(业务)?详细怎么干不用它管。所以实际上Controller = U的一部分 + IBLL。Model =【BLL(实现部分 )+ DAL】—> 容器:对象和操作。View仅仅负责展示数据结果。 


    错误观点二:

             业务划分上是正确的,错在MVC的调用关系与三层一样。      

    三层调用关系:

    1.U、B、D层自上而下依赖, 下层为上层服务;

              2.U、B、D平等关系,U层不能越级跳转到D层。 


    正确观点二:



    在MVC体系中提高了Controller(控制器)的地位。C是View与Model之间相互通信的中枢纽带。假设没有Controller的允许,View与Model是不可能进行通信的。换句话说,仅仅要Controller允许,View能够将数据给Model,Model发生了改变,也能通知给View。Controller掌握View节点间的变化和Model层中对象的操作。

     

    相应我们的java web 里面,C 相当于是Servlet、Model相当于java Bean、 View 相当于是Jsp。浏览器直接发送请求到Servlet,Servlet接受到数据转到Model层去处理,最后Servlet将保存的结果转发到JSP页面,再由JSP页面将数据展示出来。由此可见,Servlet能够相应多个JSP页面。 


    综上所诉:

           MVC在结构上发生了彻底的改变,并不同于三层。这样的变化在一定程度上带来了非常大的优点。 

    1. 效率提高了,三层是严格的调用关系,传输或是读取数据的时候,须要经过层层调用,才干获取到数据。效率大大减少了。 而View和Model能够进行通信,传输速度加快。 
    2. 解耦合,在Controller的统一管理下,用户和数据操作全然隔离。 
    3. 灵活性大大提高,Controller能够管理多个View ,这样当View发生改变时,能够任意的更换。 


    总结: 

             对事物的认识是一个一步一步加深的过程。每一步加深也许会让我们推翻自己,可是这并不代表前面我们就是错的。这一次认识的加深一定是建立在被我们推翻的观点之上。 所以,认识没有对错之分,仅仅是说在什么样的条件下,就会有什么样的认识。 


  • 相关阅读:
    php用正则表达式匹配URL的简单方法(亲测可行)
    MySQL中MyISAM与InnoDB区别及选择
    crontab定时任务语法及应用
    “购物狂欢节”如何应对“羊毛党”
    深入理解 Linux 的 RCU 机制
    白夜追凶 :手 Q 图片的显示和发送逻辑
    老司机教你如何优雅地完成一个小项目测试
    腾讯云分布式数据库可用性系统实践
    使用 Skeleton Screen 提升用户感知体验
    实战分享,教你蓝牙在小程序中的应用
  • 原文地址:https://www.cnblogs.com/gcczhongduan/p/4002631.html
Copyright © 2020-2023  润新知