当前位置: 首页 > news >正文

【设计模式】外观模式(Facade)详解

文章目录

    • 1. 引言:系统复杂,调用者太累
    • 2. 什么是外观模式
      • GoF 定义
    • 3. 外观模式的核心思想
    • 4. 外观模式的结构
    • 5. 示例:电脑启动系统
      • 5.1 子系统
      • 5.2 外观类
      • 5.3 客户端使用
    • 6. 外观模式的优点
    • 7. 外观模式的缺点
    • 8. 外观 vs 适配器 vs 桥接
    • 9. JDK 中的外观模式
      • Spring 的 JdbcTemplate
    • 10. 典型应用场景
      • 适合使用
      • 不适合使用
    • 11. 一个重要误区
    • 参考

1. 引言:系统复杂,调用者太累

在真实项目中,你经常会遇到这种代码:

CPUcpu=newCPU();Memorymemory=newMemory();Diskdisk=newDisk();cpu.start();memory.load();disk.read();

如果每个客户端都要写这一堆启动逻辑:

  • 调用顺序不能错
  • 依赖关系很复杂
  • 修改极易引发连锁问题

你会发现:

调用者被迫了解太多“系统内部细节”。

这正是外观模式要解决的问题。


2. 什么是外观模式

GoF 定义

为子系统中的一组接口提供一个统一的高层接口,使得子系统更容易使用。

详解:又名门面模式,是一种通过为多个复杂的子系统提供一个一致的接口,而使这些子系统更加容易被访问的模式。该模式对外有一个统一接口,外部应用程序不用关心内部子系统的具体的细节,这样会大大降低应用程序的复杂度,提高了程序的可维护性。

外观(Facade)模式是“迪米特法则”的典型应用

一句话理解:

给复杂系统套一个“统一入口”。


3. 外观模式的核心思想

外观模式的目标不是添加功能,也不是改变接口,而是:

隔离“使用者”和“复杂实现”。

它的本质是:

  • 对外提供简单接口
  • 对内协调多个子系统

就像一个前台,你只要找它,不必认识公司所有员工。


4. 外观模式的结构

外观模式主要包含:

  1. Facade(外观类)

为多个子系统对外提供一个共同的接口。

  1. 多个子系统类

实现系统的部分功能,客户可以通过外观角色访问它。


5. 示例:电脑启动系统

5.1 子系统

publicclassCPU{publicvoidstart(){System.out.println("CPU启动");}}
publicclassMemory{publicvoidload(){System.out.println("内存加载");}}
publicclassDisk{publicvoidread(){System.out.println("磁盘读取");}}

5.2 外观类

publicclassComputerFacade{privateCPUcpu=newCPU();privateMemorymemory=newMemory();privateDiskdisk=newDisk();publicvoidstart(){cpu.start();memory.load();disk.read();System.out.println("电脑启动完成");}}

5.3 客户端使用

ComputerFacadecomputer=newComputerFacade();computer.start();

客户端再也不用关心 CPU、内存、磁盘的启动顺序。


6. 外观模式的优点

  1. 简化客户端调用
  2. 降低系统耦合度
  3. 提高系统可维护性
  4. 屏蔽内部复杂性

7. 外观模式的缺点

  1. 外观类可能变得臃肿
  2. 过度封装可能隐藏灵活性
  3. 不符合“对修改完全关闭”

8. 外观 vs 适配器 vs 桥接

模式目的
外观简化接口
适配器转换接口
桥接分离变化维度

9. JDK 中的外观模式

Spring 的 JdbcTemplate

jdbcTemplate.query(...)

内部封装了:

  • Connection
  • Statement
  • ResultSet
  • 异常处理

👉 对外提供“数据库访问外观”。


10. 典型应用场景

适合使用

  • 系统子模块复杂
  • 调用流程固定
  • 希望对外提供统一 API
  • 微服务、SDK 封装

不适合使用

  • 子系统很简单
  • 需要细粒度控制

11. 一个重要误区

外观模式不是为了“封死子系统”,而是为了“让大多数人用简单接口”。

高级用户仍然可以直接调用底层模块。


参考

外观模式 | 菜鸟教程

《图解设计模式》

外观 - Java教程 - 廖雪峰的官方网站

http://www.jsqmd.com/news/235253/

相关文章:

  • 大语言模型在城市规划决策支持中的推理应用
  • 内存碎片|c++内存池|lua gc
  • 喂金鱼小工具
  • 深度学习计算机毕设之通过python-CNN深度学习对狗的体型识别通过机器学习对狗的体型识别
  • amd 功耗频率
  • 【课程设计/毕业设计】人工智能基于python-CNN卷积神经网络识别玻璃是否破碎基于人工智能python-CNN卷积神经网络识别玻璃是否破碎
  • AI元人文:欲望-客观-自感的纠缠治理——从三值纠缠到内生进化
  • 深度学习计算机毕设之基于python-CNN卷积神经网络识别玻璃是否破碎基于卷神经网络识别玻璃是否破碎
  • 大数据领域数据产品的旅游行业应用方案
  • 导师严选9个AI论文平台,自考学生轻松搞定论文写作!
  • 服务器/论坛试运行发布测试!
  • 低端游戏网站:在线玩260+经典DOS/Windows游戏,基于JSDOS技术
  • 被说“像 AI”的论文,最先该改的是哪里?
  • 别等系统“凉了”才响铃:聊聊延迟敏感系统的监控与报警设计
  • 深度学习毕设项目:基于python-CNN卷积神经网络识别玻璃是否破碎
  • Spring Boot 第一天:我与框架的“闪婚”之旅
  • 亲测好用的免费降ai率工具推荐:2026年最新论文降ai实操,教你如何利用ai降ai。
  • 每日Java面试场景题知识点之-检索增强生成(RAG)技术
  • 实测高效的aigc免费降重方案:针对知网维普论文降ai,提供多种免费降低ai率路径,教你如何有效降低ai率。
  • 优雅的使用Nexent创建与部署前端面试智能体
  • (新卷,200分)- 仿LISP运算(Java JS Python)
  • (新卷,200分)- 分积木(Java JS Python C)
  • Arduino IDE开发ESP8266的离线配置
  • 2026 年加密行业交易平台参考整理:用户常用平台与新手使用指引
  • 大数据领域HBase的跨集群数据复制方案
  • 谈谈你对AOP(面向切面编程)的理解,它是如何实现的?(动态代理)
  • 国家电投香港财资开启绿色金融新篇章
  • 学霸同款9个AI论文工具,专科生搞定毕业论文+格式规范!
  • 导师推荐2026最新!10款AI论文软件测评:专科生毕业论文全攻略
  • AI原生应用时代,Claude的技术优势分析