三层中的大学问

时间:2014-04-27 21:33:59   收藏:0   阅读:280


        最近也进展到了三层的学习,看了一些三层的相关的资料,


才逐渐的认识到三层的概念。

   

   当初没看之前,在学习软件工程的时候,就曾设想过一个项目


的流程也应该大致的包括三部分:需求分析、业务逻辑处理、数


据库。而当面对三层的时候,才恍然大悟,这不就是三层的影子


吗?三层到底是何方神圣呢,下面先看一副图片。


  mamicode.com,码迷


  

    大家设想一下,我们平常去饭店吃饭的场景,前脚刚进去,


服务员就笑嘻嘻的来迎接你,把你点的菜肴,交给头大的伙夫,


伙夫通过后勤人员提前准备好的菜,来做出美味的佳肴,最后再


次通过服务员反馈给你。

  


    想一下,这三个人少一个,整个流程的服务效率就会大大的


下降,就会使整个流程变得杂乱无章。这与我们的三层的是一个


道理,下面就一一揭晓三层。

 

   表示层(User Interface)

    

    所谓的表示层,就是用户接触的界面,用来为用户提供服


务的数据,例如我们经常所见的注册和登陆界面

 

  

   业务逻辑层(Business LogicLayer)

     

    从名字中就可以看出,就好比一个中转站,一个加工厂,把


用户提供的数据,经过逻辑上的加工后或者保存到数据库中,或


者直接在返回用户,起着承上启下的作用,刚好搭建了表示层和


数据访问层之间的桥梁。

 

  

   数据访问层(Data Access)

      

    仅实现对数据的保存和读取操作。就好比仓库管理员的工


作,实现对仓库的货物情况进行整理。


 

   为什么会有三层?

      

    可能我们会想,不是两层就OK了嘛,干嘛非得多出一个数据


访问层呢。让用户直接与底层的数据联系不是更有效率吗?这样


想是没有错误的。真正三层的目的,是把软件开发任务分解,有


利于团队合作开发;软件的适应性增强,一旦有什么需求变动可


以很快的进行代码更改,因而代码的复用性很高。因此为此牺牲


点效率还是很值得的。


  

   思想上移

      

    一直还都记得老师说过的坐飞机穿越森林的事情,目的在于


能够从宏观上把握整个事情的来龙去脉。如果你一头扎进去的


话,你猴年马月也估计很难理出头绪来。还记得第一次敲机房的


时候,由于没有学习软件工程、UML、设计模式,所以就是照葫芦


画瓢的过来了,就好比一头扎进森林一样,整个过程不仅很费时


间很长,而且心里上也很痛苦和烦躁,因为对眼前的事情没有头


绪,很迷乱。

     

   因此三层的出现,也是为了解决这个问题,能够让我们对软件


的整体结构分析的很清楚,并且各个环节的改动都不会影响彼


此。


   再仔细想一下,三层的出现也是必然的结果,大工厂生产的流


水线作业,不也正是三层的另一映射嘛,看来软件来自于生活的


各个方面。现在才真正的体会到编程是一门艺术这句话的真正含


义了。  



  


 

   

      


   


三层中的大学问,码迷,mamicode.com

评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!