门面模式(Facade Pattern)
定义:门面模式又叫外观模式,提供了一个统一的接口,用来访问子系统的一群接口。
特征:门面模式定义了一个高层接口,让子系统更容易使用。
属于结构性模式
门面模式的适用场景
子系统越来越复杂,增加门面模式提供简单接口
构建多层系统结构,利用门面对象作为每层的入口,简化层间调用
门面模式的通用写法(general)
// 外观角色 Facade
public class Facade {
private SubSystemA a = new SubSystemA();
private SubSystemB b = new SubSystemB();
private SubSystemC c = new SubSystemC();
// 对外接口
public void doA() {
this.a.doA();
}
// 对外接口
public void doB() {
this.b.doB();
}
// 对外接口
public void doC() {
this.c.doC();
}
}
// 子系统
public class SubSystemA {
public void doA() {
System.out.println("doing A stuff");
}
}
// 子系统
public class SubSystemB {
public void doB() {
System.out.println("doing B stuff");
}
}
// 子系统
public class SubSystemC {
public void doC() {
System.out.println("doing C stuff");
}
}
class Test {
// 客户
public static void main(String[] args) {
Facade facade = new Facade();
facade.doA();
facade.doB();
facade.doC();
}
}
一个简单实例
public class GiftInfo {
private String name;
public GiftInfo(String name) {
this.name = name;
}
public String getName() {
return name;
}
}
//支付
public class PaymentService {
public boolean pay(GiftInfo giftInfo){
System.out.println("扣减" + giftInfo.getName() + " 积分成功");
return true;
}
}
//积分
public class QualifyService {
public boolean isAvailable(GiftInfo giftInfo){
System.out.println("校验" +giftInfo.getName() + "积分通过,库存通过。");
return true;
}
}
// 物流
public class ShippingService {
public String delivery(GiftInfo giftInfo){
System.out.println(giftInfo.getName() + "进入物流系统");
String shippingNo = "666";
return shippingNo;
}
}
public class FacadeService {
private QualifyService qualifyService = new QualifyService();
private PaymentService paymentService = new PaymentService();
private ShippingService shippingService = new ShippingService();
public void exchange(GiftInfo giftInfo){
if(qualifyService.isAvailable(giftInfo)){
if(paymentService.pay(giftInfo)){
String shippingNo = shippingService.delivery(giftInfo);
System.out.println("物流系统下单成功,物流单号是:" + shippingNo);
}
}
}
}
public class Test {
public static void main(String[] args) {
FacadeService facadeService = new FacadeService();
GiftInfo giftInfo = new GiftInfo("《Spring 5核心原理》");
facadeService.exchange(giftInfo);
}
}
门面模式与代理模式
- 门面模式就是一种特殊静态代理模式
- 门面模式重点在于封装,静态代理重点是在增强
- (不做增强的静态代理就是门面模式)
门面模式和单例模式
- 门面模式做成单例:工具包、
门面模式的优点:
- 简化了调用过程,无须深入了解子系统,以防给子系统带来风险
- 减少系统依赖,减小耦合度
- 更好的划分访问层次,提高了安全性
- 遵循迪米特法则,最少知道原则
门面模式缺点:
- 当增加子系统和扩展子系统行为时,可能容易带来位置的风险
- 不符合开闭原则
- 某些情况下可能违背单一职责原则