首页 > 其他分享 >外观模式:简化复杂子系统的访问与使用

外观模式:简化复杂子系统的访问与使用

时间:2023-09-03 22:02:18浏览次数:40  
标签:外观 接口 public 简化 模式 子系统 客户端



文章目录

  • 1. 简介
  • 2. 外观模式的基本结构
  • 3. 外观模式的实现步骤
  • 4. 外观模式的应用与实例
  • 4.1 图形界面库的外观模式应用
  • 4.2 文件压缩与解压缩的外观模式应用
  • 4.3 订单处理系统的外观模式应用
  • 5. 外观模式的优缺点
  • 5.1 优点
  • 5.2 缺点
  • 6. 总结


1. 简介

外观模式是一种结构型设计模式,它提供了一个统一的接口,用于简化复杂子系统的访问和使用。通过外观模式,可以隐藏子系统的复杂性,并将其封装在一个高层接口之后,使得客户端可以通过调用这个外观接口来间接地访问子系统的功能。外观模式有助于降低系统的耦合度,提高系统的灵活性和可维护性。

2. 外观模式的基本结构

外观模式由以下几个核心角色组成:

  • 客户端角色(Client):通过外观接口与子系统进行交互。
  • 外观角色(Facade):封装了子系统的复杂性,提供简单的高层接口给客户端使用。
  • 子系统角色(Subsystem):负责具体的功能实现。

3. 外观模式的实现步骤

通过以下步骤可以实现外观模式:

  1. 定义子系统的各个组件及其功能,确保每个组件都能够独立工作。
  2. 创建外观类,将子系统的功能封装在外观类中。
  3. 在外观类中实现对子系统的统一访问接口,这个接口应该简单明了。
  4. 客户端通过外观类来访问子系统,无需直接与子系统的组件进行交互。

代码示例:

// 子系统组件A
class SubsystemA {
    public void operationA() {
        // 实现具体的功能逻辑
    }
}

// 子系统组件B
class SubsystemB {
    public void operationB() {
        // 实现具体的功能逻辑
    }
}

// 外观类
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 Client {
    public static void main(String[] args) {
        Facade facade = new Facade();
        facade.operation();
    }
}
4. 外观模式的应用与实例

4.1 图形界面库的外观模式应用

在图形界面库中,可能存在各种复杂的子系统组件,如窗口、按钮、标签等。使用外观模式可以将这些组件封装在一个高层的外观类中,客户端只需通过外观类来操作这些组件,从而简化了客户端的使用过程。

4.2 文件压缩与解压缩的外观模式应用

在文件压缩与解压缩过程中,可能需要调用各种算法和组件来完成。使用外观模式可以将这些复杂的操作封装在一个高层的外观类中,对外提供简单的接口,使得客户端可以方便地进行文件压缩和解压缩的操作。

4.3 订单处理系统的外观模式应用

在订单处理系统中,可能涉及到多个子系统组件,如库存管理、支付系统、物流跟踪等。使用外观模式可以将这些组件封装在一个高层的外观类中,对外提供统一的接口,使得客户端可以方便地处理订单,而不需要关注底层子系统的具体实现细节。
下面是一个简单的订单处理系统的外观模式示例:

// 库存管理子系统
class InventorySystem {
    public void updateInventory(String productId, int quantity) {
        // 更新库存逻辑
        System.out.println("更新库存:产品ID:" + productId + " 数量:" + quantity);
    }
}

// 支付系统子系统
class PaymentSystem {
    public void processPayment(String orderId, double amount) {
        // 处理支付逻辑
        System.out.println("支付处理:订单ID:" + orderId + " 金额:" + amount);
    }
}

// 物流跟踪子系统
class LogisticsSystem {
    public void shipOrder(String orderId) {
        // 发货逻辑
        System.out.println("发货处理:订单ID:" + orderId);
    }
}

// 外观类 - 订单处理系统
class OrderProcessingFacade {
    private InventorySystem inventorySystem;
    private PaymentSystem paymentSystem;
    private LogisticsSystem logisticsSystem;

    public OrderProcessingFacade() {
        inventorySystem = new InventorySystem();
        paymentSystem = new PaymentSystem();
        logisticsSystem = new LogisticsSystem();
    }

    public void processOrder(String productId, int quantity, double amount) {
        String orderId = generateOrderId();

        // 更新库存
        inventorySystem.updateInventory(productId, quantity);

        // 处理支付
        paymentSystem.processPayment(orderId, amount);

        // 发货
        logisticsSystem.shipOrder(orderId);

        // 其他订单处理的逻辑
        // ...
    }

    private String generateOrderId() {
        // 生成订单ID的逻辑
        return "12345";
    }
}

// 客户端代码
public class Client {
    public static void main(String[] args) {
        OrderProcessingFacade facade = new OrderProcessingFacade();
        String productId = "ABC123";
        int quantity = 10;
        double amount = 100.0;
        facade.processOrder(productId, quantity, amount);
    }
}

外观模式:简化复杂子系统的访问与使用_客户端

在上述示例中,我们模拟了一个订单处理系统,包含了库存管理、支付系统和物流跟踪等子系统组件。通过外观模式,我们将这些子系统组件封装在OrderProcessingFacade外观类中,并提供了统一的接口processOrder用于处理订单。

客户端代码中,创建了一个OrderProcessingFacade实例,并调用processOrder方法来处理订单。客户端无需关注底层子系统的具体实现细节,只需要通过外观类来操作订单,从而简化了客户端的使用过程。

注意:上述示例为了简化演示,并未添加详细的业务逻辑,实际应用中可能需要更加完善的实现。

5. 外观模式的优缺点

5.1 优点

  • 简化接口,降低使用难度:外观模式提供了一个简单的高层接口,隐藏了底层子系统的复杂性,使得客户端更容易使用。
  • 解耦子系统,提高灵活性和可维护性:通过外观类,将客户端与子系统分离,使得子系统的变化不会影响到客户端,提高了系统的灵活性和可维护性。
  • 提供高层次接口,简化系统架构:外观模式可以作为系统的一部分,提供更高层次的接口,简化了系统的架构。

5.2 缺点

  • 违背开闭原则:如果需要新增或修改功能,可能需要修改外观类的代码。
  • 不符合单一职责原则:外观类承担了过多的责任,可能变得庞大而复杂。
6. 总结

外观模式,也称为门面模式,是一种结构型设计模式,旨在将复杂的子系统封装为一个简单易用的接口,以减少系统的复杂度并提高代码的可维护性和灵活性。

外观模式通过定义一个高层接口来隐藏子系统的底层复杂性,使得客户端无需了解和调用复杂的子系统逻辑和接口,而只需调用简单易用的外观类接口即可完成相应的操作。这样,极大地简化了客户端调用代码,并提高了代码的可读性、可维护性和扩展性。

外观模式对于软件开发有着很多的积极影响:

  1. 降低系统复杂度:外观模式可以将系统中复杂的子系统进行封装,从而将系统的复杂度降低到合理的水平。

  2. 提高代码可维护性:外观模式将子系统进行封装,减少了客户端与子系统之间的耦合,从而让系统变得更加易于维护。

  3. 提高代码的可读性:外观模式将子系统的复杂逻辑隐藏在外观类后面,使得代码变得更加简洁、易读。

  4. 改善代码的结构性:外观模式可以提高代码的结构性,使得代码更加规范、易懂。

  5. 提高代码的可扩展性:外观模式提供了一个简单的接口,当需要添加新的子系统时,只需要在外观类中添加相应的方法实现,而不影响客户端代码。

总的来说,外观模式在软件开发中有着广泛的应用,它能够显著地提高代码的可维护性、可读性、可扩展性和结构性。同时,它也有助于降低软件的复杂度,使得软件开发变得更加简单、易于实现。




标签:外观,接口,public,简化,模式,子系统,客户端
From: https://blog.51cto.com/u_15918766/7343556

相关文章

  • MindSponge分子动力学模拟——定义一个分子系统(2023.08)
    技术背景在前面两篇文章中,我们分别介绍了分子动力学模拟软件MindSponge的软件架构和安装与使用教程。这里我们进入到实用化阶段,假定大家都已经在本地部署好了基于MindSpore的MindSponge的编程环境,开始用MindSponge去做一些真正的分子模拟的工作。那么分子模拟的第一步,我们就需要......
  • Parallels Desktop 19 for Mac 发布, 简化 macOS 和 Windows 交互
    ParallelsDesktop19forMac发布,简化macOS和Windows交互ParallelsDesktop19BusinessEdition请访问原文链接:https://sysin.org/blog/parallels-desktop-19/,查看最新版。原创作品,转载请保留出处。作者主页:sysin.orgAugust21,2023Mac爱好者大家好,这是多么令......
  • 14.4K Star,一款外观漂亮、运行快速、动画细腻的开源免费UI组件库
    之前给大家推荐了很多后台模版,有读者希望推荐一些跟通用的好看组件,毕竟出了后台还有很多其他场景嘛。所以,今天继续给大家推荐一个广受好评的UI组件库:NextUI主要特性NextUI的主要目标是简化开发流程,为增强的用户体验提供美观且适应性强的系统设计。它有以下几点核心特性:可个......
  • Linux 内核音频子系统调试
    debugfs文件系统debugfs可以为Linux内核各个模块的分析调试,提供许多信息,如音频子系统的ASoC,以及tracing等。debugfs文件系统可以通过命令行工具挂载,如下所示:root@apollo:~#ls/sys/kernel/debug/root@apollo:~#mount-tdebugfsnodev/sys/kernel/debugroot@apollo......
  • 【Windows 11】安装 Android子系统 和 Linux子系统
    本文使用电脑系统:文章目录一、安卓子系统1.1安装WSA1.2使用二、Linux子系统2.1安装WSL以及WSL相关概念2.2安装一个Linux发行版2.21从MicrosoftStore安装2.22用命令安装2.23拓展三、拓展3.1存储位置3.2虚拟化技术3.3Windows虚拟内存3.3wsl帮助文件一、安卓子系......
  • 简化版本的kissat--Sat Solver SATCH
       SatSolverSATCHThisisthesourcecodeofSATCHaSATsolverwrittenfromscratchinC.Theactualversionnumbercanbefoundin VERSION andchangesinthelatestreleasearedocumentedin NEWS.md.Themainpurposeofthissolveristoprov......
  • 12 pinctrl 和 gpio 子系统实验
    一、pinctrl子系统1.什么是pinctrl子系统?  首先回顾一下如何初始化LED所使用的GPIO:①、修改设备树,添加相应的节点,节点里面重点是设置reg属性,reg属性包括了GPIO相关寄存器。②、获取reg属性中GPIOI_MODER、GPIOI_OTYPER、GPIOI_OSPEEDR、GPIOI_PUPDR和GPI......
  • 10、简化条件逻辑
    条件表达式的复杂度往往关系到整个软件的复杂度10.1、分解条件表达式避免条件表达式过长,难于理解,所以该封装封装10.2、合并条件表达式有时候,在我们的程序中包含这样一些条件检查,检查条件不同,但行为一致,在这种情况下,我们可以考虑合并条件检查,相反,如果你任务这些条件检......
  • position简化
    .some-element{position:absolute;inset:0;}如果你对 top 、 right 、 bottom 和 left 有不同的值,你可以按照如下的顺序分别设置它们: inset:-10px0px-10px0px 。这种简写方式与margin 的工作方式相同。......
  • 利用Docker简化机器学习应用程序的部署和可扩展性
    利用Docker的强大功能:简化部署解决方案,确保可扩展性,并简化机器学习模型的持续集成/持续交付(CI/CD)流程。机器学习(ML)近年来取得了爆炸性增长,导致对稳健、可扩展和高效部署方法的需求增加。传统方法往往需要帮助将ML模型操作化,原因包括训练和服务环境之间的差异或扩展的困难。Docker是......