网站设计兼职,注册网站查询,wordpress基于,市场来说网站建设销售发展怎么样外观模式#xff08;Facade Pattern#xff09;
概念 外观模式#xff08;Facade Pattern#xff09;是一种结构型设计模式#xff0c;旨在为复杂子系统提供一个简化的统一接口。通过外观模式#xff0c;客户端可以与子系统交互#xff0c;而无需了解子系统的内部复杂性…外观模式Facade Pattern
概念 外观模式Facade Pattern是一种结构型设计模式旨在为复杂子系统提供一个简化的统一接口。通过外观模式客户端可以与子系统交互而无需了解子系统的内部复杂性。这种模式为客户端屏蔽了复杂系统的细节使得客户端使用系统时变得更简单。 应用场景 简化客户端与复杂系统的交互在一个复杂的系统中如果客户端需要与多个子系统进行交互外观模式通过提供一个简化的接口隐藏了系统的复杂性。例如图形系统、数据库操作、第三方接口等往往有多个复杂的接口外观模式可以为这些接口提供统一入口。 减少类之间的耦合客户端只需与外观类交互而不需要直接调用多个子系统接口从而降低了客户端与子系统之间的耦合度增强了系统的可维护性。 层次化结构外观模式可以用于设计层次化系统每一层提供一个外观类减少上下层的相互依赖。例如Web应用程序中业务层可能会通过外观类来调用底层的持久化层和其他服务。 注意点
外观类不应包含太多业务逻辑外观类的职责应是简化接口而不是实现复杂的业务逻辑。实际业务逻辑应由子系统负责处理。外观模式并不强制子系统内部结构的简化它只是对客户端提供了一个简化的接口子系统内部仍然可能非常复杂。可扩展性问题如果子系统发生变化外观类可能需要随着调整。 核心要素
Facade外观类为客户端提供简化的接口封装复杂的子系统接口调用。Subsystem子系统类复杂子系统的一部分通常是多个类组成的系统外观类通过这些子系统类完成各种功能。客户端Client使用外观类来与子系统交互客户端无需知道子系统的细节。 Java代码完整示例
// 子系统A
class SubsystemA {public void operationA() {System.out.println(子系统A的操作);}
}// 子系统B
class SubsystemB {public void operationB() {System.out.println(子系统B的操作);}
}// 子系统C
class SubsystemC {public void operationC() {System.out.println(子系统C的操作);}
}// 外观类
class Facade {private SubsystemA subsystemA;private SubsystemB subsystemB;private SubsystemC subsystemC;public Facade() {subsystemA new SubsystemA();subsystemB new SubsystemB();subsystemC new SubsystemC();}// 提供简化的接口public void performOperation() {subsystemA.operationA();subsystemB.operationB();subsystemC.operationC();}
}// 客户端
public class Client {public static void main(String[] args) {Facade facade new Facade();facade.performOperation();}
}输出结果
子系统A的操作
子系统B的操作
子系统C的操作各种变形用法完整示例 分层外观模式 在复杂系统中多个子系统可能会存在多层次的依赖关系可以为每一层提供一个外观类。例如在一个大型企业级系统中可以有数据层、业务逻辑层和表示层的外观类。 代码示例 // 数据层外观类
class DataLayerFacade {private SubsystemA subsystemA;private SubsystemB subsystemB;public DataLayerFacade() {subsystemA new SubsystemA();subsystemB new SubsystemB();}public void dataLayerOperation() {subsystemA.operationA();subsystemB.operationB();}
}// 业务层外观类
class BusinessLayerFacade {private DataLayerFacade dataLayerFacade;private SubsystemC subsystemC;public BusinessLayerFacade() {dataLayerFacade new DataLayerFacade();subsystemC new SubsystemC();}public void businessLayerOperation() {dataLayerFacade.dataLayerOperation();subsystemC.operationC();}
}// 客户端
public class ClientLayered {public static void main(String[] args) {BusinessLayerFacade businessLayerFacade new BusinessLayerFacade();businessLayerFacade.businessLayerOperation();}
}双重外观模式 双重外观模式是将多个外观模式结合使用客户端可以选择使用不同的外观类来访问不同的子系统。例如一个系统可能包含多个独立模块每个模块有自己的外观类客户端可以选择使用特定模块的外观类。 代码示例 // 外观A
class FacadeA {private SubsystemA subsystemA;private SubsystemB subsystemB;public FacadeA() {subsystemA new SubsystemA();subsystemB new SubsystemB();}public void operationA() {subsystemA.operationA();subsystemB.operationB();}
}// 外观B
class FacadeB {private SubsystemC subsystemC;public FacadeB() {subsystemC new SubsystemC();}public void operationB() {subsystemC.operationC();}
}// 客户端
public class ClientMultipleFacades {public static void main(String[] args) {FacadeA facadeA new FacadeA();facadeA.operationA();FacadeB facadeB new FacadeB();facadeB.operationB();}
}与单例模式结合的外观模式 外观模式常与单例模式结合使用以确保系统中的外观类只有一个实例减少系统开销确保统一的接口访问。 代码示例 // 外观类使用单例模式
class SingletonFacade {private static SingletonFacade instance;private SubsystemA subsystemA;private SubsystemB subsystemB;private SingletonFacade() {subsystemA new SubsystemA();subsystemB new SubsystemB();}public static SingletonFacade getInstance() {if (instance null) {instance new SingletonFacade();}return instance;}public void performOperations() {subsystemA.operationA();subsystemB.operationB();}
}// 客户端
public class ClientSingletonFacade {public static void main(String[] args) {SingletonFacade facade SingletonFacade.getInstance();facade.performOperations();}
}总结 外观模式的主要作用是简化客户端对复杂系统的访问。通过引入外观类系统的可维护性、可扩展性和模块化得到了提升。装饰者模式和外观模式的不同之处在于装饰者模式注重在运行时增加功能而外观模式侧重于为子系统提供一个简化的接口。