设计模式之门面模式

门面模式(Facade Pattern)定义

门面模式(Facade Pattern)也叫做外观模式,是一种比较常用的封装模式,其定义如 下:Provide a unified interface to a set of interfaces in a subsystem.Facade defines a higher-level interface that makes the subsystem easier to use.(要求一个子系统的外部与其内部的通信必须通过一个统一的对象进行。门面模式提供一个高层次的接口,使得子系统更易于使用。)
在这里插入图片描述
简单的说,就是对外界提供一个接口来访问系统内部

角色分析

  • Facade门面角色
  • subsystem子系统角色

门面角色:知晓子系统内部的所有功能和责任,一般情况下,该角色只是一个委托类,没有实际的执行权。

子系统角色:可以同时有一个或者多个子系统每一个子系统都不是一个单独的类,而是由多个类组成的集合。子系统并不知道门面的存在。对于子系统而言,门面仅仅是另外一个客户端而已。

就拿我们常说的日志门面slf4j(Simple Logging Facade for Java)来说,发现Logger类中都是抽象方法
在这里插入图片描述
再来看看logback,发现它实现了 slf4j 的全部方法,当我们项目中用的是slf4j + lockback时,我们通过门面slf4j就可以调用真正的执行者logback。当然,如果我想悄悄的换一个执行者,比如log4j,通过实现 slf4j 的全部方法也可以做到,而且,外界根本感知不到。
在这里插入图片描述

门面模式的优缺点

门面模式的优点
  • 提高了灵活性
  • 提高安全性
  • 减少系统的相互依赖(避免外界访问直接深入到子系统内部)
门面模式的缺点
  • 不符合开闭原则

适用的场景

  • 为一个复杂的模块或子系统提供一个供外界访问的接口
  • 子系统相对独立——外界对子系统的访问只要黑箱操作即可
  • 预防低水平人员带来的风险扩散

门面不参与子系统内的业务逻辑

下面这段代码,就使得门面也参与了业务的逻辑处理

public class Facade { //被委托的对象,也就是门面
 private ClassA a = new ClassA(); 
 private ClassB b = new ClassB(); 
 private ClassC c = new ClassC(); 
 //提供给外部访问的方法 
 public void methodA(){ 
	 this.a.doSomethingA(); 
 }
 public void methodB(){ 
 	this.b.doSomethingB(); 
 }
 //这个方法让门面进行了业务处理
 public void methodC(){  
 	this.a.doSomethingA(); 
	 this.c.doSomethingC(); 
 } 
}

门面对象只提供一个能访问子系统的路径,仅此而已,它不应该也不能参与具体的业务逻辑,否则就会产生一个倒依赖的问题:
子系统必须依赖门面才能被访问,这是设计上一个严重错误,不仅违反了单一职责原则,同时也破坏了系统的封装性。

提示:阿里巴巴明确规定,使用SLF4J做为日志的门面。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

罗罗的1024

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值