java23种设计模式-外观模式

外观模式(Facade Pattern)学习笔记

🌟 定义

外观模式 属于结构型设计模式,提供一个统一的接口来访问子系统中的多个接口。它通过定义一个高层接口简化客户端与复杂子系统的交互。


🎯 适用场景

  1. 为复杂子系统提供简单入口
  2. 解耦客户端与子系统
  3. 分层构建系统(各层通过外观类交互)
  4. 遗留系统重构(用外观类封装旧接口)

🔧 模式结构

📐 类图

Client Facade -subsystemA: SubsystemA -subsystemB: SubsystemB -subsystemC: SubsystemC +operation() SubsystemA +operationA() SubsystemB +operationB() SubsystemC +operationC()


🛠️ 核心组成

  1. Facade(外观角色)

    • 知道子系统功能
    • 将客户端请求委派给对应子系统对象
  2. Subsystem Classes(子系统角色)

    • 实现子系统具体功能
    • 不感知外观存在(可独立运行)

📝 代码示例

家庭影院场景

java 复制代码
// 子系统类
class Lights {
    void dim() { System.out.println("灯光调暗"); }
}

class SoundSystem {
    void on() { System.out.println("音响开启"); }
}

class Projector {
    void down() { System.out.println("幕布降下"); }
}

// 外观类
class HomeTheaterFacade {
    private Lights lights;
    private SoundSystem sound;
    private Projector projector;

    public HomeTheaterFacade() {
        this.lights = new Lights();
        this.sound = new SoundSystem();
        this.projector = new Projector();
    }

    public void watchMovie() {
        lights.dim();
        sound.on();
        projector.down();
    }
}

// 客户端
public class Client {
    public static void main(String[] args) {
        HomeTheaterFacade facade = new HomeTheaterFacade();
        facade.watchMovie(); // 一键启动观影模式
    }
}

✅ 优点

  • 简化客户端使用复杂度
  • 客户端与子系统松耦合
  • 更好的访问控制(可限制直接访问子系统)
  • 符合迪米特法则(最少知识原则)

⚠️ 缺点

  • 过度使用会导致系统层级过多
  • 增加维护成本(修改子系统可能需调整外观)
  • 可能成为"上帝对象"(需注意职责划分)

🔄 相关模式对比

模式 区别
中介者模式 关注子系统间的通信协调
单例模式 外观类常实现为单例
抽象工厂模式 可与外观结合封装创建过程

💡 实践建议

  1. 优先考虑子系统重构而不是外观包装
  2. 保持外观类的单一职责
  3. 可创建多个外观类对应不同使用场景
  4. 通过依赖注入管理子系统对象

掌握外观模式的关键在于理解它作为系统门户的定位,合理使用可以显著提升系统的易用性和可维护性。

相关推荐
星空寻流年6 小时前
设计模式第一章(建造者模式)
java·设计模式·建造者模式
蒋星熠7 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
至此流年莫相忘10 小时前
设计模式:策略模式
设计模式·策略模式
ytadpole11 小时前
揭秘设计模式:命令模式-告别混乱,打造优雅可扩展的代码
java·设计模式
努力也学不会java14 小时前
【设计模式】 外观模式
设计模式·外观模式
deepwater_zone15 小时前
设计模式(策略,观察者,单例,工厂方法)
设计模式
宁静致远202118 小时前
【C++设计模式】第三篇:观察者模式(别名:发布-订阅模式、模型-视图模式、源-监听器模式)
c++·观察者模式·设计模式
User_芊芊君子1 天前
【Java】设计模式——单例、工厂、代理模式
java·设计模式·代理模式
YA3331 天前
java设计模式二、工厂
java·开发语言·设计模式
烛阴1 天前
【TS 设计模式完全指南】从零到一:掌握TypeScript建造者模式,让你的对象构建链式优雅
javascript·设计模式·typescript