web11 三层架构

什么是三层?
表示层 :主要是指与用户交互的界面,用于接收用户输入的数据和显示处理后用户需要的数据
业务逻辑层 :表示层和数据库访问层之间的桥梁,实现业务逻辑,具体包含:验证、计算、业务规则等等
数据访问层 :与数据库打交道,主要实现对数据的增、删、改、查

三层架构的理解
生活中的三层架构:

顾客:相当于客户端

服务员:展示餐厅的菜品(展示数据),相当于表示层

厨师:处理食材(处理数据),相当于逻辑处理层

采购员:收购食材(获取数据),相当于数据访问

除了以上的三层外,还有一层是entity层:实体层

三层模式的划分
表示层
业务逻辑层
数据库访问层


 三层架构的特征
各司其职:

服务员就是专门和顾客直接交流的,为顾客点菜 厨师只需要根据顾客点的菜来做 采购员只需根据顾客的菜准备食材,交给厨师即可

三层架构:

表示层就相当于服务员,专门和用户打交道,获取用户的操作 业务逻辑层就相当于厨师,从数据访问层拿来数据,根据表示层传来的用户操作去执行操作 数据访问层就相当于采购员,用户需要什么数据,就从数据库或是文件中拿来此数据,交给业务逻辑层

为什么使用三层?
用三层架构的目的就是为了实现高内聚低耦合的思想:

高内聚:尽可能类的每个成员方法只完成一件事

低耦合:减少类内部,一个成员方法调用另一个成员方法

从类角度来看, 高内聚低耦合:减少类内部,对其他类的调用

从功能块来看, 高内聚低耦合:减少模块之间的交互复杂度

简单来说,就是 解耦:只做自己功能内的事

服务员(UI层)请假—>另找服务员

厨师(BLL层)辞职—>招聘另一个厨师

采购员(DAL)辞职—>招聘另一个采购员

任何一层发生变化都不会影响到另外一层!!!

三层与两层的区别:
两层:


当任何一个地方发生变化时,都需要重新开发整个系统。“多层”放在一层,分工不明确耦合度高,难以适应需求变化,可维护性低、可扩展性低

 三层:


 发生在哪一层的变化,只需更改该层,不需要更改整个系统。层次清晰,分工明确,每层之间耦合度低,提高了效率,适应需求变化,可维护性高,可扩展性高

为什么需要分层
       JSP开发的弊端 
业务处理的代码与JSP代码混在一起,不易于阅读,不易于代码维护   

分层模式
分层模式是最常见的一种架构模式
分层模式是很多架构模式的基础
分层
将解决方案的组件分隔到不同的层中
在同一个层中组件之间保持内聚性
层与层之间保持松耦合
面向接口编程
设计与实现分开

在一个面向对象的系统中,系统的各种功能是由许许多多的不同对象协作完成的。

在这种情况下,各个对象内部是如何实现自己的,对系统设计人员来讲就不那么重要了;

而各个对象之间的协作关系则成为系统设计的关键。

小到不同类之间的通信,大到各模块之间的交互,在系统设计之初都是要着重考虑的,

这也是系统设计的主要工作内容。面向接口编程就是指按照这种思想来编程。

实现方式


 

biz: 存放业务逻辑层的接口

biz.impl:存放业务逻辑层的实现类

dao:存放数据访问层的接口

dao.impl:存放数据访问层的实现类
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值