设计模式:外观模式

目录

外观模式是一种结构型设计模式,它提供了一个统一的接口,用于访问子系统中的一组接口。外观模式隐藏了子系统的复杂性,使得客户端能够更简单地使用子系统的功能。

外观模式的核心思想是将复杂的子系统封装在一个外观类中,客户端只需要与外观类进行交互,而不需要直接与子系统的各个组件进行交互。外观类充当了客户端与子系统之间的中间层,简化了客户端的操作过程。

通过外观模式,客户端可以通过调用外观类的方法来完成一系列复杂的操作,而无需了解子系统内部的具体实现细节。外观模式提供了一种简单、直观的接口,使得客户端能够更方便地使用子系统的功能。

组件

  1. 子系统类:子系统中的具体类或对象,负责完成特定的功能或任务。
  2. 外观类:外观模式的核心,封装了子系统的组件,并提供简化的接口给客户端使用。
  3. 客户端:使用外观模式的代码,通过外观类来访问子系统的功能,而不需要直接与子系统的组件进行交互。
  4. 接口:子系统中的各个组件可能会定义接口,用于定义其行为和规范。
  5. 工具类:在外观模式中,可能会使用一些工具类来辅助封装和管理子系统的组件。

代码实例

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

在上面的示例中,我们有两个子系统类(SubsystemA和SubsystemB),它们分别实现了不同的操作。然后我们创建了一个外观类(Facade),它封装了这两个子系统,并提供了一个简化的接口给客户端使用。最后,在客户端代码中,我们通过实例化外观类并调用其操作方法来使用外观模式。

这个示例展示了外观模式如何通过封装子系统的复杂性,提供一个简化的接口给客户端使用。客户端只需要与外观类交互,而不需要直接与子系统的组件进行交互。

源码中应用

在源码中,外观模式有很多应用场景。以下是一些常见的源码中应用外观模式的情况:

  1. Java标准库中的类:

    • java.util.Collections类提供了一系列静态方法,封装了对集合的常见操作,如排序、查找等。
    • javax.servlet.http.HttpServlet类封装了处理HTTP请求的方法,简化了开发Web应用的过程。
  2. Spring框架中的类:

    • org.springframework.jdbc.core.JdbcTemplate类封装了与数据库交互的方法,简化了数据库操作的流程。
    • org.springframework.web.servlet.DispatcherServlet类作为前端控制器,封装了处理HTTP请求的逻辑,简化了Web应用的开发。

优缺点

优点:

  1. 简化客户端使用:外观模式提供了一个简化的接口给客户端使用,隐藏了子系统的复杂性,使得客户端更容易理解和使用。
  2. 解耦子系统和客户端:外观模式将子系统与客户端解耦,使得它们可以独立演化,互不影响。
  3. 提高代码的可维护性:通过外观模式,将复杂的子系统封装在一个外观类中,使得系统更易于维护和修改。

缺点:

  1. 不符合开闭原则:当需要修改或添加子系统的功能时,可能需要修改外观类,违背了开闭原则。
  2. 增加了类的数量:引入外观模式会增加一个外观类,可能会导致类的数量增加,增加了系统的复杂性。

总结

外观模式通过封装子系统的复杂性,提供了一个简化的接口给客户端使用。它简化了客户端的操作过程,提高了代码的可维护性。然而,使用外观模式需要权衡其优点和缺点,确保合理使用。

相关推荐
hanbarger2 分钟前
mybatis框架——缓存,分页
java·spring·mybatis
cdut_suye10 分钟前
Linux工具使用指南:从apt管理、gcc编译到makefile构建与gdb调试
java·linux·运维·服务器·c++·人工智能·python
苹果醋322 分钟前
2020重新出发,MySql基础,MySql表数据操作
java·运维·spring boot·mysql·nginx
小蜗牛慢慢爬行23 分钟前
如何在 Spring Boot 微服务中设置和管理多个数据库
java·数据库·spring boot·后端·微服务·架构·hibernate
azhou的代码园26 分钟前
基于JAVA+SpringBoot+Vue的制造装备物联及生产管理ERP系统
java·spring boot·制造
捕鲸叉35 分钟前
C++软件设计模式之外观(Facade)模式
c++·设计模式·外观模式
小小小妮子~1 小时前
框架专题:设计模式
设计模式·框架
先睡1 小时前
MySQL的架构设计和设计模式
数据库·mysql·设计模式
wm10431 小时前
java web springboot
java·spring boot·后端
smile-yan1 小时前
Provides transitive vulnerable dependency maven 提示依赖存在漏洞问题的解决方法
java·maven