揭秘外观模式:简化复杂系统的关键设计策略

前言

外观模式(Facade Pattern)是一种结构型设计模式,它隐藏了系统的复杂性,并向客户端提供了一个可以访问系统的接口。这种类型的设计模式向现有的系统添加一个接口,来隐藏系统的复杂性。这种模式涉及到一个单一的类,该类提供了客户端请求的简化方法和对现有系统类方法的委托调用。
在软件工程中,外观模式主要用于简化接口和封装调用,特别是当需要调用多个复杂的子系统时。通过引入一个高层接口,外观模式能够使得子系统更加容易使用。

外观模式的结构

外观模式通常包括以下角色:

  1. Facade(外观):这是系统中唯一与客户端交互的类。它为客户端提供一组简化的接口,用于访问子系统中的功能。外观类知道如何组织这些子系统来完成客户端的请求。

  2. Subsystem(子系统):子系统包含一系列的类,这些类实现了系统的部分功能。通常,这些类之间存在相互依赖关系,对外表现为复杂的操作接口。

  3. Client(客户端):客户端是使用外观类的消费者。通过外观类,客户端可以访问到子系统中的功能,而无需直接与子系统的各个部分进行交互。

以上角色的关系如图表示:
在这里插入图片描述
其中,Subsystem1和Subsystem2是两个子系统接口,它们分别定义了不同的操作。ConcreteSubsystem1和ConcreteSubsystem2是这两个接口的具体实现。Facade是外观类,它包含了对子系统的引用,并提供了统一的request()方法供客户端调用。

在Java中的应用

在Java中,外观模式可以通过创建一个或多个外观类来实现,这些类封装了对子系统的访问和操作。例如,如果有一个复杂的文件系统操作,可以创建一个外观类来简化文件的打开、读取、写入和关闭操作。

class FileSystem {
    public void openFile() { /* ... */ }
    public void readFile() { /* ... */ }
    public void writeFile() { /* ... */ }
    public void closeFile() { /* ... */ }
}

class FileSystemFacade {
    private FileSystem fileSystem;

    public FileSystemFacade(FileSystem fileSystem) {
        this.fileSystem = fileSystem;
    }

    public void performOperations() {
        fileSystem.openFile();
        fileSystem.readFile();
        fileSystem.writeFile();
        fileSystem.closeFile();
    }
}

在这个例子中,FileSystem类代表了复杂的子系统,而FileSystemFacade类则是外观类,它提供了一个简化的接口performOperations(),用于执行一系列文件操作。

优点

  1. 简化接口:外观模式为复杂的子系统提供了一个简洁的接口,使得客户端无需了解子系统内部的复杂逻辑。

  2. 减少依赖:客户端只依赖于外观类,从而减少了客户端与子系统之间的依赖关系,提高了系统的可维护性和扩展性。

  3. 提高可用性:外观模式可以封装子系统的变化,保护客户端免受影响,从而提高系统的可用性。

  4. 分层设计:通过外观类,可以将不同的子系统组合起来形成一个层次结构的系统,每一层都只需要与其下一层交互。

缺点

  1. 增加抽象层:引入外观类意味着增加了系统的抽象层,这可能会导致系统的性能有所下降。

  2. 可能违反单一职责原则:如果外观类的职责过多,可能会违反单一职责原则,导致外观类变得臃肿。

  3. 限制直接访问:客户端不能直接访问子系统中的类,这可能会在某些情况下限制客户端的功能。

应用场景

外观模式的核心在于引入一个外观类,这个类为复杂的子系统提供一个简单的接口,使得客户端不需要直接与子系统的内部组件进行交互。外观模式的应用场景主要包括:

  1. 简化接口:当一个系统具有复杂的多个子系统时,外观模式可以提供一个统一的高层接口,简化客户端的操作。
  2. 减少依赖:通过外观角色,客户端对子系统的依赖性降低,从而减少了系统的耦合度。
  3. 提高可用性:外观模式可以隐藏子系统的复杂性,使得客户端无需了解复杂的实现细节,从而提高了系统的易用性。
  4. 控制访问:外观模式还可以用于控制对子系统内部组件的访问,从而实现对子系统的安全访问或者访问控制。
  5. 优化性能:有时候,通过外观角色可以进行一些性能优化,比如缓存子系统的数据,减少对子系统的频繁访问。
  6. 重构遗留系统:在对遗留系统进行重构时,外观模式可以用来逐步替换旧的系统组件,而不会影响到其他部分的正常使用。

结论

在实际应用中,外观模式可以帮助我们更好地组织和管理代码,提高系统的可维护性和扩展性。如果你需要提供一个统一的接口来简化系统的复杂性,且不考虑客户端直接访问那么请采用外观模式吧。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/384146.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Linux进程间通信】用管道实现简单的进程池、命名管道

【Linux进程间通信】用管道实现简单的进程池、命名管道 目录 【Linux进程间通信】用管道实现简单的进程池、命名管道为什么要实现进程池?代码实现命名管道创建一个命名管道 理解命名管道匿名管道与命名管道的区别命名管道的打开规则 作者:爱写代码的刚子…

《Git 简易速速上手小册》第7章:处理大型项目(2024 最新版)

文章目录 7.1 Git Large File Storage (LFS)7.1.1 基础知识讲解7.1.2 重点案例:在 Python 项目中使用 Git LFS 管理数据集7.1.3 拓展案例 1:使用 Git LFS 管理大型静态资源7.1.4 拓展案例 2:优化现有项目中的大文件管理 7.2 性能优化技巧7.2.…

刘知远LLM——神经网络基础

文章目录 神经网络基础基本构成如何训练? Word2Vec例子负采样: 循环神经网络 RNN门控计算单元 GRU长短时记忆网络 LSTM遗忘门输入门输出门双向RNN卷积神经网络 CNNpytorch实战 神经网络基础 基本构成 全称:人工神经网络。启发于生物神经细胞…

[VulnHub靶机渗透] WestWild 1.1

🍬 博主介绍👨‍🎓 博主介绍:大家好,我是 hacker-routing ,很高兴认识大家~ ✨主攻领域:【渗透领域】【应急响应】 【python】 【VulnHub靶场复现】【面试分析】 🎉点赞➕评论➕收藏…

全面详细对比@Resource和@Autowired

版权声明 本文原创作者:谷哥的小弟作者博客地址:http://blog.csdn.net/lfdfhl Resource和Autowired概述 在Java的Spring框架中,Resource和Autowired都是用于实现依赖注入(Dependency Injection, DI)的重要注解。依赖…

视频号流量真大,对新手非常友好

你好,我是小生,一个程序员转型做自媒体副业中~ 最近几天,做自媒体圈的同频朋友在测试视频号直播,目的是为了快速涨粉不违规,春节的流量 视频号推荐,这个组合非常完美。 经过测试数据看出来,开播…

C#,21根火柴棍问题(21 Matchticks Problem)的算法与源代码

一、21根火柴棍问题(21 Matchticks Problem) 21根火柴棍问题是西方经典游戏之一。 给定21根火柴,2个人A和B(比如:分别是计算机和用户)。 每个人一次可以挑选 1-- 4 根火柴。 被迫挑最后一根火柴的人输了…

计算机网络——网络安全

计算机网络——网络安全 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家, [跳转到网站](https://www.captainbed.cn/qianqiu) 小程一言专栏链接: [link](http://t.csdnimg.cn/ZUTXU) 网络安全何…

配置DNS正反向解析服务!!!!

一.准备工作 #关闭防火墙和selinux,或者允许服务通过 [rootnode ~]# nmcli c mod ens32 ipv4.method manual ipv4.address 192.168.32.133/24 ipv4.gateway 192.168.32.2 ipv4.dns 192.168.32.132 [rootnode ~]# nmcli c reload [rootnode ~]# nmcli c up ens32[rootnode ~]# …

2.12.。

1、选择芯片型号——STM32F051K8 2、开启调试功能 3、配置时钟 4、配置时钟树 5、工程管理

基于Qt的人脸识别项目(功能:颜值检测,口罩检测,表情检测,性别检测,年龄预测等)

完整代码链接在文章末尾 效果展示 代码讲解(待更新) qt图片文件上传 #include <QtWidgets> #include <QFileDialog>

Linux diff命令

参考资料 【 diff 】コマンド&#xff08;基本編&#xff09;――テキストファイルの差分を出力する便利なdiffコマンド使い方 目录 前期准备一. 基本语法二. 文件比较2.1 无配置项2.2 -B 忽略空行&#xff0c;-w忽略空格2.3 -y 文件内容横向比较显示2.4 -q 仅显示文件是否不同…

UR10+gazebo+moveit吸盘抓取搬运demo

使用ur10gazebo开发了一个简易吸盘抓取箱子码垛的仿真过程&#xff0c;机械臂控制使用的是moveit配置。 本博客对部分关键的代码进行解释。 代码运行环境&#xff1a;支持ubuntu16、 18、 20&#xff0c; ros版本是ros1&#xff08;经过测试&#xff09;。 1、搬运场景 场景的…

单页404源码

<!doctype html> <html> <head> <meta charset"utf-8"> <title>简约 404错误页</title><link rel"shortcut icon" href"./favicon.png"><style> import url("https://fonts.googleapis.co…

Servlet验证技术

验证技术 验证是验证用户信息并确定该用户是否有权访问服务器资源的过程。用于验证用户信息的各种验证技术包括: 基本验证基于表单的验证摘要验证客户机整数验证1. 基本验证 网站可能包含两种类型的网站,即受保护和不受保护网页。默认情况下,所有用户都可以访问不受保护或者…

数据分析基础之《pandas(8)—综合案例》

一、需求 1、现在我们有一组从2006年到2016年1000部最流行的电影数据 数据来源&#xff1a;https://www.kaggle.com/damianpanek/sunday-eda/data 2、问题1 想知道这些电影数据中评分的平均分&#xff0c;导演的人数等信息&#xff0c;我们应该怎么获取&#xff1f; 3、问题…

线性代数的本质——1 向量

向量是线性代数中最为基础的概念。 何为向量&#xff1f; 从物理上看&#xff0c; 向量就是既有大小又有方向的量&#xff0c;只要这两者一定&#xff0c;就可以在空间中随便移动。 从计算机应用的角度看&#xff0c;向量和列表很接近&#xff0c;可以用来描述某对象的几个不同…

C||1.水仙花数是指一个n位数,每一位数字的n次幂的和正好等于这个数本身。2.有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数。

1.水仙花数是指一个n位数&#xff0c;每一位数字的n次幂的和正好等于这个数本身。 比如&#xff1a;153 13 53 33。 要求打印出所有三位数的水仙花数。 #include <stdio.h> #include <math.h> int main() {int i,x,y,z;for(i100;i<1000;i){xi/100%10;yi/10%…

力扣_字符串6—最小覆盖字串

题目 给你一个字符串 s 、一个字符串 t 。返回 s 中涵盖 t 所有字符的最小子串。如果 s 中不存在涵盖 t 所有字符的子串&#xff0c;则返回空字符串 “” 。 示例 &#xff1a; 输入&#xff1a;s “ADOBECODEBANC”, t “ABC” 输出&#xff1a;“BANC” 解释&#xff1a;…