外观模式(Facade Pattern)

简介: 外观模式(Facade Pattern)是一种结构型设计模式,为子系统中的一组接口提供一个一致的接口。它通过一个高层接口简化子系统的复杂性,使客户端更容易使用。外观模式的核心角色包括外观(Facade)和子系统(Subsystems),主要优点是降低复杂性和松耦合,适用于简化接口、分层设计和遗留代码集成等场景。

外观模式(Facade Pattern)详解

定义

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


核心概念

角色组成

  1. 外观(Facade)
    为复杂子系统提供简单的接口,负责协调子系统的调用。
  2. 子系统(Subsystems)
    一组实现功能的复杂模块,对外部隐藏其内部细节。

特性

  • 降低复杂性:屏蔽子系统的实现细节,提供简单接口。
  • 松耦合:客户端与子系统之间通过外观解耦。

外观模式的类图


使用场景

  1. 简化接口:隐藏复杂系统的内部细节,为外部提供一个简单的调用接口。
  2. 分层设计:降低客户端与复杂子系统之间的耦合。
  3. 遗留代码集成:在使用遗留代码时,通过外观模式统一管理,避免直接依赖。

优缺点分析

优点

  1. 简化接口:隐藏复杂实现细节。
  2. 松耦合:子系统的变化不影响客户端代码。
  3. 更易维护:减少直接依赖,增强系统的可维护性。

缺点

  1. 不完全封装:若客户端仍直接调用子系统,外观的效果会减弱。
  2. 职责单一性可能被破坏:外观可能成为“大接口”,过于复杂。

使用案例

案例 1:智能家居控制

  • 描述:智能家居系统包含灯光、空调和安防模块。外观模式可提供一个统一的接口,如“回家模式”,一键控制所有子系统。
  • 实现:灯光、空调、安防模块作为子系统,外观封装具体调用逻辑。

案例 2:数据库访问

  • 描述:在复杂的数据库操作中,外观模式可统一处理查询、事务管理和日志记录。
  • 实现:将底层数据库驱动操作封装为统一接口,客户端仅需调用外观。

知识点对比表

特性 外观模式 直接调用子系统
接口复杂度 简单统一 复杂,需了解多个接口
耦合性 松耦合 紧耦合
适应性 易于扩展和修改 扩展时影响客户端
使用场景 封装复杂子系统 客户端需灵活控制子系统

C++ 实现

#include <iostream>
using namespace std;

// 子系统A
class SubsystemA {
public:
   void methodA() const {
       cout << "SubsystemA: methodA executed." << endl;
   }
};

// 子系统B
class SubsystemB {
public:
   void methodB() const {
       cout << "SubsystemB: methodB executed." << endl;
   }
};

// 子系统C
class SubsystemC {
public:
   void methodC() const {
       cout << "SubsystemC: methodC executed." << endl;
   }
};

// 外观类
class Facade {
private:
   SubsystemA subsystemA;
   SubsystemB subsystemB;
   SubsystemC subsystemC;

public:
   void operation1() {
       cout << "Facade: operation1 executing." << endl;
       subsystemA.methodA();
       subsystemB.methodB();
   }

   void operation2() {
       cout << "Facade: operation2 executing." << endl;
       subsystemC.methodC();
   }
};

// 客户端代码
int main() {
   Facade facade;
   facade.operation1();
   facade.operation2();
   return 0;
}


C# 实现

using System;

// 子系统A
public class SubsystemA {
   public void MethodA() {
       Console.WriteLine("SubsystemA: MethodA executed.");
   }
}

// 子系统B
public class SubsystemB {
   public void MethodB() {
       Console.WriteLine("SubsystemB: MethodB executed.");
   }
}

// 子系统C
public class SubsystemC {
   public void MethodC() {
       Console.WriteLine("SubsystemC: MethodC executed.");
   }
}

// 外观类
public class Facade {
   private SubsystemA subsystemA = new SubsystemA();
   private SubsystemB subsystemB = new SubsystemB();
   private SubsystemC subsystemC = new SubsystemC();

   public void Operation1() {
       Console.WriteLine("Facade: Operation1 executing.");
       subsystemA.MethodA();
       subsystemB.MethodB();
   }

   public void Operation2() {
       Console.WriteLine("Facade: Operation2 executing.");
       subsystemC.MethodC();
   }
}

// 客户端代码
class Program {
   static void Main(string[] args) {
       Facade facade = new Facade();
       facade.Operation1();
       facade.Operation2();
   }
}


总结

  1. 高层接口:外观模式简化了复杂子系统的使用。
  2. 降低耦合:实现了客户端与子系统的解耦。
  3. 推荐场景:适用于隐藏复杂实现逻辑,统一接口调用的场景。
目录
相关文章
|
设计模式 算法
设计模式7 - 门面模式【Facade Pattern】
设计模式7 - 门面模式【Facade Pattern】
66 1
|
设计模式
设计模式8 - 适配器模式【Adapter Pattern】
设计模式8 - 适配器模式【Adapter Pattern】
58 0
|
1月前
|
设计模式 C# C++
适配器模式(Adapter Pattern)
适配器模式是一种结构型设计模式,通过将一个类的接口转换为客户期望的另一个接口,使原本接口不兼容的类可以一起工作。它包括目标接口、适配者和适配器三个核心角色。适配器模式常用于解决旧系统兼容性问题、第三方库整合和统一接口等场景。该模式有类适配器和对象适配器两种实现方式,分别通过继承和组合实现。适配器模式的优点包括提高兼容性、遵循开闭原则和灵活性高,但也存在适配器数量增加导致复杂性和可能影响性能的缺点。
72 1
|
4月前
|
设计模式 Java
设计模式--适配器模式 Adapter Pattern
这篇文章介绍了适配器模式,包括其基本介绍、工作原理以及类适配器模式、对象适配器模式和接口适配器模式三种实现方式。
|
应用服务中间件 智能硬件 容器
结构型模式 - 外观模式(Facade Pattern)
结构型模式 - 外观模式(Facade Pattern)
|
Java 程序员 API
结构型模式 - 适配器模式(Adapter Pattern)
结构型模式 - 适配器模式(Adapter Pattern)
|
设计模式 Java 程序员
适配器模式(Adapter Pattern)
适配器模式是一种结构型设计模式, 它能将接口转换为客户期望的另一个接口,也就是说它能使接口不兼容的对象能够相互合作。
137 0
适配器模式(Adapter Pattern)
|
设计模式 Java 数据库连接
门面模式 Facade Pattern
主要内容有: 该模式的介绍,包括: 引子、意图(大白话解释) 类图、时序图(理论规范) 该模式的代码示例:熟悉该模式的代码长什么样子 该模式的优缺点:模式不是万金油,不可以滥用模式 该模式的应用案例:了解它在哪些重要的源码中被使用
174 0
|
设计模式 JSON Java
【愚公系列】2021年12月 二十三种设计模式(十)-外观模式(Facade Pattern)
【愚公系列】2021年12月 二十三种设计模式(十)-外观模式(Facade Pattern)
134 0
【愚公系列】2021年12月 二十三种设计模式(十)-外观模式(Facade Pattern)
|
Java C#
使用C# (.NET Core) 实现适配器模式 (Adapter Pattern) 和外观模式 (Facade Pattern)
本文的概念内容来自深入浅出设计模式一书 现实世界中的适配器(模式) 我带着一个国标插头的笔记本电脑, 来到欧洲, 想插入到欧洲标准的墙壁插座里面, 就需要用中间这个电源适配器. 面向对象的适配器 你有个老系统, 现在来了个新供应商的类, 但是它们的接口不同, 如何使用这个新供应商的类呢? 首先, 我们不想修改现有代码, 你也不能修改供应商的代码.
1774 0