java设计模式:03-05-外观模式
创始人
2024-12-26 03:35:02
0

外观模式(Facade Pattern)

外观模式(Facade Pattern)是一种结构型设计模式,它为子系统中的一组接口提供一个一致的界面。外观模式定义了一个高层接口,使得子系统更容易使用。

外观模式的应用场景

  • 为一个复杂子系统提供一个简单接口:如数据库操作、文件系统操作等。
  • 减少客户端与子系统之间的耦合:客户端只需要与外观对象交互,而不需要了解子系统的细节。
  • 希望层次化子系统,建立一组松散耦合的子系统:如三层架构中的数据访问层、业务逻辑层和表示层。

外观模式的实现方式

1. 传统实现方式

思想:通过定义一个外观类,该外观类将复杂的子系统接口简化成一个简单的接口供客户端使用。

实现方式

// 子系统类A class SubsystemA {     public void operationA() {         System.out.println("SubsystemA operation");     } }  // 子系统类B class SubsystemB {     public void operationB() {         System.out.println("SubsystemB operation");     } }  // 子系统类C class SubsystemC {     public void operationC() {         System.out.println("SubsystemC operation");     } }  // 外观类 class Facade {     private SubsystemA subsystemA;     private SubsystemB subsystemB;     private SubsystemC subsystemC;      public Facade() {         subsystemA = new SubsystemA();         subsystemB = new SubsystemB();         subsystemC = new SubsystemC();     }      public void operation() {         subsystemA.operationA();         subsystemB.operationB();         subsystemC.operationC();     } }  // 客户端代码 public class FacadePattern {     public static void main(String[] args) {         Facade facade = new Facade();         facade.operation();     } } 

优点

  • 简化了客户端与子系统的交互,使得子系统更易于使用。
  • 客户端与子系统之间的耦合度降低,客户端不需要知道子系统的具体实现。
  • 符合单一职责原则,外观类负责与客户端交互,子系统类负责具体功能实现。

缺点

  • 增加了额外的外观类,如果子系统接口已经足够简洁,增加外观类可能显得多余。
  • 可能会隐藏一些子系统的功能,限制了灵活性。
2. 参数化外观模式

思想:通过传递参数来配置外观类的行为,使得外观类更加灵活和可配置。

实现方式

// 子系统类A class SubsystemA {     public void operationA() {         System.out.println("SubsystemA operation");     } }  // 子系统类B class SubsystemB {     public void operationB() {         System.out.println("SubsystemB operation");     } }  // 子系统类C class SubsystemC {     public void operationC() {         System.out.println("SubsystemC operation");     } }  // 外观类 class ConfigurableFacade {     private SubsystemA subsystemA;     private SubsystemB subsystemB;     private SubsystemC subsystemC;      public ConfigurableFacade() {         subsystemA = new SubsystemA();         subsystemB = new SubsystemB();         subsystemC = new SubsystemC();     }      public void operation(boolean useA, boolean useB, boolean useC) {         if (useA) subsystemA.operationA();         if (useB) subsystemB.operationB();         if (useC) subsystemC.operationC();     } }  // 客户端代码 public class ConfigurableFacadePattern {     public static void main(String[] args) {         ConfigurableFacade facade = new ConfigurableFacade();         facade.operation(true, false, true);     } } 

优点

  • 提供了灵活的配置选项,使得外观类可以根据具体需求调整行为。
  • 仍然简化了客户端与子系统的交互,降低了耦合度。

缺点

  • 使得外观类的接口变得复杂,不如传统外观模式简洁。
  • 需要客户端传递参数来配置外观类的行为,增加了使用的复杂性。

总结

实现方式优点缺点
传统实现方式简化客户端与子系统的交互,降低耦合度,符合单一职责原则增加额外的外观类,如果子系统接口已经足够简洁,显得多余
参数化外观模式提供灵活配置选项,使得外观类行为可调整,仍然简化客户端与子系统交互接口变得复杂,不如传统外观模式简洁,需要客户端传递参数

选择哪种实现方式应根据具体的需求和系统的复杂度来决定。如果需要简化客户端与子系统的交互,可以选择传统实现方式。如果需要外观类更加灵活和可配置,可以选择参数化外观模式。

相关内容

热门资讯

围绕透视问题!hhpoker德... 围绕透视问题!hhpoker德州有挂吗,广西友乐软件辅助,真是是有辅助插件(哔哩哔哩)1、让任何用户...
每日必看教程!微信小程序免费黑... 每日必看教程!微信小程序免费黑科技(外挂),微乐小程序微乐房间怎么开挂果然今日头条1、下载好微信小程...
必备透视!拱趴大菠萝自动计算机... 必备透视!拱趴大菠萝自动计算机器人,werplan怎么作必弊(透视)原来存在有辅助教程(哔哩哔哩)1...
透视演示!大菠萝免费辅助(透视... 透视演示!大菠萝免费辅助(透视)总是存在有辅助app(哔哩哔哩)1、玩家可以在大菠萝免费辅助线上大神...
现就发布提示!hhpoker必... 现就发布提示!hhpoker必备开挂,小程序牵手跑得快有外g挂吗,确实是真的有辅助脚本(哔哩哔哩);...
实测交流!微乐小程序黑科技(外... 实测交流!微乐小程序黑科技(外挂),微乐自建房脚本使用安全吗一贯有挂方法1、进入到微乐小程序黑科技是...
曝光透视!哈糖大菠萝攻略,哈糖... 曝光透视!哈糖大菠萝攻略,哈糖大菠萝软件下载(透视)竟然存在有辅助神器(哔哩哔哩)1、进入到哈糖大菠...
透视秘籍!德州局透视脚本免费版... 透视秘籍!德州局透视脚本免费版下载手机版(透视)总是是有辅助修改器(哔哩哔哩)1、起透看视 德州局透...
重大发现!微乐小程序免费黑科技... 重大发现!微乐小程序免费黑科技(外挂),微乐小程序怎么挂脚本一直有挂分析1)微乐小程序免费黑科技免费...
长期以来!哈糖大菠萝助手,越乡... 长期以来!哈糖大菠萝助手,越乡游辅助器,真是有辅助工具(哔哩哔哩)1、不需要AI权限,帮助你快速的进...