门面设计模式
介绍
Java门面模式(Facade Pattern)是一种结构型设计模式,它提供了一个简单的接口,隐藏了复杂系统的实现细节,使得客户端可以更加容易地使用系统.
在Java门面模式中,一个门面对象(Facade)提供了一个简单的接口,该接口包装了一个或多个复杂的子系统,客户端可以直接使用门面对象来访问子系统,而无需直接与子系统交互,门面对象将客户端的请求转发到适当的子系统对象,然后将子系统对象的响应返回给客户端.这样,客户端就不需要知道子系统内部的细节,也不需要与多个子系统对象进行交互,从而降低了系统的复杂性和耦合性.
门面模式有以下两种角色:
- 门面(Facade)角色:门面角色是整个门面模式的核心,它提供了一个简单的接口,隐藏了系统的复杂性.门面角色知道将客户端请求发送给那些子系统对象,如何将这些请求转发给子系统对象,以及如何将子系统对象的响应返回给客户端.
- 子系统(Subsystem)角色:子系统角色是实现系统功能的各个部分.子系统角色是与门面角色相对应的,它们是门面角色所封装的具体功能实现.子系统角色处理门面角色传递过来的请求,并返回处理结果.
实现
假设有一个在线购物系统,其中包含了库存管理,订单管理和支付管理等多个子系统.现在需要对这些子系统进行封装,提供了一个简单的接口给客户端使用.这时就可以使用Java门面模式来实现.
首先定义一个订单类
@Data
public class Order {private String itemId;private int quantity;public Order(String itemId, int quantity) {this.itemId = itemId;this.quantity = quantity;}
}
然后定义子系统角色
public class InventoryManagement {/*** 检查库存** @param itemId* @param quantity* @return*/public boolean checkInventory(String itemId, int quantity) {System.out.println("检查库存");return true;}
}public class OrderManagement {/*** 创建订单** @param itemId* @param quanitity* @return*/public Order createOrder(String itemId, int quanitity) {System.out.println("创建订单");return new Order(itemId, quanitity);}
}public class PaymentManagement {/*** 支付订单** @param order* @param paymentMethod*/public void makePayment(Order order, String paymentMethod) {System.out.println("支付订单");}
}
最后定义门面类,作为整个门面模式的核心
public class OnlineShoppingFacade {private InventoryManagement inventoryManagement;private OrderManagement orderManagement;private PaymentManagement paymentManagement;public OnlineShoppingFacade(InventoryManagement inventoryManagement, OrderManagement orderManagement, PaymentManagement paymentManagement) {this.inventoryManagement = inventoryManagement;this.orderManagement = orderManagement;this.paymentManagement = paymentManagement;}/*** 下单操作** @param itemId* @param quantity* @param paymentMenthod*/public void placeOrder(String itemId, int quantity, String paymentMenthod) {System.out.println("开始处理下单操作...");boolean checkInventory = inventoryManagement.checkInventory(itemId, quantity);if (!checkInventory) {throw new RuntimeException("库存不足");}Order order = orderManagement.createOrder(itemId, quantity);paymentManagement.makePayment(order, paymentMenthod);}
}
测试
public class Demo {public static void main(String[] args) {OnlineShoppingFacade onlineShoppingFaced = new OnlineShoppingFacade(new InventoryManagement(),new OrderManagement(),new PaymentManagement());onlineShoppingFaced.placeOrder("123",3,"Wechat");}
}
在这个示例中,我们创建了一个门面类OnlineShoppingFacade,该门面类封装了库存管理,订单管理和支付管理三个子系统对象.客户端只需要使用OnlineShoppingFacade类提供得placeOrder()方法,就可以完成下单操作.通过这种方式,我们将整个下单过程封装在OnlineShoppingFacade门面类中,使得客户端无需了解底层子系统对象得实现细节,只需要调用门面类提供得方法即可完成操作.这样,我们就实现了一个简单的Java门面示例.
总结
优点
- 简化客户端代码:门面模式可以隐藏底层子系统对象的实现细节,使得客户端只需要调用门面类提供的方法即可完成操作,从而简化了客户端代码的复杂度.
- 解耦合:门面模式可以将客户端与底层子系统对象解耦合,从而使得底层子系统对象的修改对客户端代码的影响降到最低.
- 提高安全性:门面模式可以将一些敏感操作封装起来,只允许客户端通过门面类进行访问,从而提高了安全性.
缺点
- 可能增加系统复杂度:如果门面类实现不当,可能会增加系统复杂度.
- 可能降低灵活性:如果需要新增子系统对象或修改子系统对象的实现细节,可能需要修改门面类的代码,从而降低了系统的灵活性.
应用场景
- 当一个系统包含多个子系统,可客户端需要使用这些子系统完成某个操作时,可以考虑使用门面模式封装这些子系统.
- 当客户端需要调用一些敏感的操作时,可以使用门面模式将这些操作封装起来,从而提高系统的安全性,
- 当客户端需要使用多个复杂的子系统对象完成某个操作时,可以使用门面模式简化客户端的代码复杂度.
总之,Java门面模式适用于那些需要将复杂系统拆分成多个子系统对象,并将这些子系统对象封装起来以简化客户端的代码复杂度和提高系统的安全性的情况.
相关文章:

门面设计模式
介绍 Java门面模式(Facade Pattern)是一种结构型设计模式,它提供了一个简单的接口,隐藏了复杂系统的实现细节,使得客户端可以更加容易地使用系统. 在Java门面模式中,一个门面对象(Facade)提供了一个简单的接口,该接口包装了一个或多个复杂的子系统,客户端可以直接使用门面对象…...

苹果手写笔好用吗?比较好用的ipad手写笔推荐
随着技术的进步,各种新型的电子产品和数码器件层出不穷。比如智能手机、IPAD、以及电容笔。而在实际生活中,为了更好的利用ipad,我们需要一支好用的电容笔。就好比如我们在ipad上做笔记,要用手来进行手写记录,会很不方…...

GPT-4来了!看看她究竟强在哪里!
GPT-4来了!OpenAI老板Sam Altman直接开门见山地介绍说:这是我们迄今为止功能最强大的模型!GPT-4是一个超大的多模态模型,也就是说,它的输入可以是文字(上限2.5万字),还可以是图像。我…...

GPT-4 API 接口调用及价格分析
GPT-4 API 接口调用及价格分析 15日凌晨,OpenAI发布了万众期待的GPT-4!新模型支持多模态,具备强大的识图能力,并且推理能力和回答准确性显著提高。在各种专业和学术基准测试上的表现都媲美甚至超过人类。难怪OpenAI CEO Sam Altm…...
MySQL高级功能:存储过程、触发器、事务、备份和恢复
MySQL高级功能MySQL是一款广泛使用的关系型数据库管理系统,它不仅具有基本的数据库功能,还支持一些高级功能,如存储过程、触发器、事务、备份和恢复等。这些高级功能可以帮助开发人员更高效地管理和维护数据库,本文将介绍MySQL的高…...

SAP 发出商品业务配置
SAP发出商品业务配置,即: 出具销售发票时结转成本 一、业务背景: 发出商品业务简单的理解为跨月开票,即出库与开票不在同一个月份。 该业务在系统内的实现方式,为保证成本与收入的配比,在出库时不计算成…...

C++线程池理解
线程池基本信息 线程池是一种结合池化思想衍生出来的一种线程管理及使用的方案 其主要针对服务器端多线程场景下,服务器频繁接收请求,每个请求都分配一个单独的线程去处理。 使用线程的开销: 创建和销毁线程调度线程 线程池主要解决的核…...

2023年最新软著申请流程(一):软件著作权说明、国家版权官网的账号注册与实名认证
若该文为原创文章,转载请注明原文出处 本文章博客地址:https://hpzwl.blog.csdn.net/article/details/129230460 红胖子(红模仿)的博文大全:开发技术集合(包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软…...

SuperMap iServer如何发布S3对象存储中的瓦片
作者:Carlo 前言: S3 对象存储服务是一个基于对象的海量存储服务,为客户提供海量、安全、高可靠、低成本的数据存储能力。其海量、安全的特性,为存储海量瓦片提供可能。 SuperMap iServer 支持将存储在阿里云对象存储 (OSS)、华为…...
ElasticSearch-第四天
目录 ElasticSearch文档分值_score计算底层原理 relevance score算法 Term frequency Inverse document frequency Field-length norm 分析一个document上的_score是如何被计算出来的 分词器工作流程 切分词语 内置分词器的介绍 定制分词器 ik分词器详解 IK分词器自…...

基于鲸鱼算法的极限学习机(ELM)分类算法-附代码
基于鲸鱼算法的极限学习机(ELM)分类算法 文章目录基于鲸鱼算法的极限学习机(ELM)分类算法1.极限学习机原理概述2.ELM学习算法3.分类问题4.基于鲸鱼算法优化的ELM5.测试结果6.参考文献7.Matlab代码摘要:本文利用鲸鱼算法对极限学习机进行优化,并用于分类问…...
一文彻底读懂webpack常用配置
开发环境 const webpack require("webpack"); const path require(path) module.exports {// entry: {// a: ./src/0706/a.js,// c: ./src/0706/c.js,// },entry: "./src/0707/reactDemo.js",output: {filename: [name]_dist.js,path: path.resolve(__…...

大环境不好,找工作太难?三面阿里,幸好做足了准备,已拿offer
三面大概九十分钟,问的东西很全面,需要做充足准备,就是除了概念以外问的有点懵逼了(呜呜呜)。回来之后把这些题目做了一个分类并整理出答案(强迫症的我狂补知识)分为软件测试基础、Python自动化…...
C++ 手撸简易服务器(完善版本)
本文没有带反射部分内容,可以看我之前发的 Server.h #pragma once#include <string> #include <iostream> #include <thread> #include <unordered_map> using namespace std; #ifndef _SERVER_ #define _SERVER_#include <winsock.h&…...
【Python入门第三十四天】Python丨文件处理
文件处理是任何 Web 应用程序的重要组成部分。 Python 有几个用于创建、读取、更新和删除文件的函数。 文件处理 在 Python 中使用文件的关键函数是 open() 函数。 open() 函数有两个参数:文件名和模式。 对于刚学Python的小伙伴,我给大家准备了2023…...

【Linux】写一个基础的bash
头文件#include<stdio.h> #include<stdlib.h> #include<unistd.h> #include<sys/wait.h> #include<sys/stat.h> #include<string.h> #include<pwd.h> #include<dirent.h>分割输入的命令串字符串或参数内容为空则退出strtok( ,…...

图解如何一步步连接远程服务器——基于VScode
基于VScode连接远程服务器 安装Remote-SSH等插件 想要在vscode上连接远程服务器需要下载Remote-SSH系列插件: 直接在插件中搜索remote,即可找到,选择图片中的3个插件,点击install安装。 配置Remote-SSH 在这个步骤有多种操作…...
element - - - - - 你不知道的loading使用方式
求人不如求己 你不知道的loading使用方式1. 指令方式使用1.1 默认loading1.2 自定义loading1.3 整页加载2. 服务方式使用2.1 this.$loading的使用2.2 Loading.service的使用关于页面交互,最害怕的就是接口等待时间太长,用户体验不好。 而如何提高用户体…...
C++程序调用IsBadReadPtr或IsBadWritePtr引发内存访问违例问题的排查
目录 1、问题描述 2、VS中看不到有效的信息,尝试使用Windbg去分析 3、使用Windbg分析 4、最后...
IntelliJIDEA 常用快捷键
IntelliJIDEA 常用快捷键 Alt Enter 导入包,自动修正,自动创建变量名。 Ctrl Alt O 优化导入的类和包 Ctrl / 单行注释 (//) Ctrl Shift / 多行注释 (/* … */) 方法或类说明注释(文档注释) 在一个方法或类的开头…...

以下是对华为 HarmonyOS NETX 5属性动画(ArkTS)文档的结构化整理,通过层级标题、表格和代码块提升可读性:
一、属性动画概述NETX 作用:实现组件通用属性的渐变过渡效果,提升用户体验。支持属性:width、height、backgroundColor、opacity、scale、rotate、translate等。注意事项: 布局类属性(如宽高)变化时&#…...
可靠性+灵活性:电力载波技术在楼宇自控中的核心价值
可靠性灵活性:电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中,电力载波技术(PLC)凭借其独特的优势,正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据,无需额外布…...

visual studio 2022更改主题为深色
visual studio 2022更改主题为深色 点击visual studio 上方的 工具-> 选项 在选项窗口中,选择 环境 -> 常规 ,将其中的颜色主题改成深色 点击确定,更改完成...

华为OD机试-食堂供餐-二分法
import java.util.Arrays; import java.util.Scanner;public class DemoTest3 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseint a in.nextIn…...

NFT模式:数字资产确权与链游经济系统构建
NFT模式:数字资产确权与链游经济系统构建 ——从技术架构到可持续生态的范式革命 一、确权技术革新:构建可信数字资产基石 1. 区块链底层架构的进化 跨链互操作协议:基于LayerZero协议实现以太坊、Solana等公链资产互通,通过零知…...

多种风格导航菜单 HTML 实现(附源码)
下面我将为您展示 6 种不同风格的导航菜单实现,每种都包含完整 HTML、CSS 和 JavaScript 代码。 1. 简约水平导航栏 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport&qu…...
Java多线程实现之Thread类深度解析
Java多线程实现之Thread类深度解析 一、多线程基础概念1.1 什么是线程1.2 多线程的优势1.3 Java多线程模型 二、Thread类的基本结构与构造函数2.1 Thread类的继承关系2.2 构造函数 三、创建和启动线程3.1 继承Thread类创建线程3.2 实现Runnable接口创建线程 四、Thread类的核心…...
稳定币的深度剖析与展望
一、引言 在当今数字化浪潮席卷全球的时代,加密货币作为一种新兴的金融现象,正以前所未有的速度改变着我们对传统货币和金融体系的认知。然而,加密货币市场的高度波动性却成为了其广泛应用和普及的一大障碍。在这样的背景下,稳定…...

Docker 本地安装 mysql 数据库
Docker: Accelerated Container Application Development 下载对应操作系统版本的 docker ;并安装。 基础操作不再赘述。 打开 macOS 终端,开始 docker 安装mysql之旅 第一步 docker search mysql 》〉docker search mysql NAME DE…...

Mysql中select查询语句的执行过程
目录 1、介绍 1.1、组件介绍 1.2、Sql执行顺序 2、执行流程 2.1. 连接与认证 2.2. 查询缓存 2.3. 语法解析(Parser) 2.4、执行sql 1. 预处理(Preprocessor) 2. 查询优化器(Optimizer) 3. 执行器…...