当前位置: 首页 > news >正文

结构性设计模式之Facade(外观)设计模式

结构性设计模式之Facade(外观)设计模式

前言:
外观模式:用自己的话理解就是用户看到是一个总体页面,比如xx报名系统页面。里面有历年真题模块、报名模块、教程模块、首页模块… 做了一个各个模块的合并,对用户操作起来比较简单,用户不必知道里面有什么系统。

摘要:
Facade(外观)模式是一种结构性设计模式,它通过提供一个统一的高层接口来简化复杂子系统的使用。该模式的意图是为子系统中的一组接口提供一致的界面,使其更容易被调用。

主要特点包括:

Facade类了解子系统的内部结构,将客户端请求代理给适当的子系统对象
子系统类实现具体功能,但不知道Facade的存在
适用于需要简化复杂系统接口、降低系统耦合度或构建层次化子系统的情况
示例代码展示了如何通过Facade类统一调用多个子系统的功能方法(methodOne、methodTwo等)。这种模式特别适合需要隐藏系统复杂性或提高系统可维护性的场景。

1)意图

为子系统中一组接口提供一个一致的界面,Facade 模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。

2)结构

在这里插入图片描述
其中:

  • Facade 知道哪些子系统类负责处理请求;将客户的请求代理给适当的子系统对象。
  • Subsystem classes 实现子系统的功能;处理有Facade对象指派的任务;没有Facade的任何相关信息,既没有指向Facade的指针。

3)适用于

Facade 模式适用于:

  • 要为一个复杂系统提供一个简单接口时。
  • 客户程序与抽象类的实现部分之间存在很大的依赖性。
  • 当需要构建一个层次结构的子系统时,使用Facade模式定义子系统中每层的入口点。
/*** @author psd 结构性设计模式之【Facade】外观模式*/
public class FacadeDemo {public static void main(String[] args) {Facade facade = new Facade();facade.methodOne();facade.methodTwo();facade.methodThree();}
}class Facade{private final FadeThree fadeThree;private final FacadeTwo fadeTwo;private final FacadeOne fadeOne;public Facade() {fadeThree = new FadeThree();fadeTwo = new FacadeTwo();fadeOne = new FacadeOne();}public void methodOne(){fadeOne.methodOne();}public void methodTwo(){fadeTwo.methodTwo();}public void methodThree(){fadeThree.methodThree();}
}class FadeThree{public void methodThree(){System.out.println("执行子任务第三个功能....");}
}class FacadeTwo{public void methodTwo(){System.out.println("执行子任务第二个功能....");}
}
class FacadeOne{public void methodOne(){System.out.println("执行子任务第一个功能....");}
}

要为一个复杂子系统提供一个简单接口时,子系统往往因为不断演化而变得越来越复杂。大多数模式使用时都会产生更多更小的类,这使得子系统更具有可重用性,也更容易对子系统进行定制,但也给那些不需要定制子系统的用户带来一些使用上的困难。Facade 可以提供一个简单的默认视图,这一视图对大多数用户来说已经足够,而那些需要更多的可定制性的用户可以越过 Facade 层

客户程序与抽象类的实现部分之间存在着很大的依赖性。引入Facade将这个子系统与客户以及其他的子系统分离,可以提高子系统的独立性和可移植性。

**当需要构建一个层次结构的子系统时,使用Facade 模式定义子系统中每层的入口点。**如果子系统之间是相互依赖的,则可以让它们仅通过 Facade 进行通信,从而简化了它们之间的依赖关系。

喜欢我的文章记得点个在看,或者点赞,持续更新中ing…

相关文章:

  • 【二分图 图论】P9384 [THUPC 2023 决赛] 着色|普及+
  • SpringAI(GA):Nacos2下的分布式MCP
  • vue 打包报错 Cannot find module ‘@vue/cli-plugin-babel/preset‘ - thread-loader
  • vue-16(Vuex 中的模块)
  • 2025年渗透测试面试题总结-腾讯[实习]安全研究员(题目+回答)
  • IEEE ICBCTIS 2025 会议征稿:探索区块链与信息安全的前沿学术之旅​
  • 学习STC51单片机27(芯片为STC89C52RCRC)
  • PageHelper-分页插件
  • PaddleOCR(2):PaddleOCR环境搭建
  • 文本内容变化引起布局尺寸变化 导致的 UI 适配问题
  • DuckDB + Spring Boot + MyBatis 构建高性能本地数据分析引擎
  • day 44
  • 深入解析FutureTask:原理与实战
  • 【从0-1的HTML】第3篇:html引入css的3种方式
  • Golang——7、包与接口详解
  • Redisson - 实现延迟队列
  • DAY43 复习日
  • 压测软件-Jmeter
  • MySQL 9.0 相较于 MySQL 8.0 引入了多项重要改进和新特性
  • 机器学习基础(四) 决策树
  • 厦门网站推广步骤机构/新闻热点
  • 外贸网站建设哪家比较好/百度手机极速版
  • 电子商务网站建设需要什么/广告公司推广平台
  • 绍兴网站建设公司地址/阿里指数网站
  • 发稿类别是什么/sem和seo是什么职业
  • jsp做网站 案例/长沙seo培训