C++设计模式:门面模式(十二)

news/2024/10/20 10:51:27/
1、概念与定义
  • “接口隔离”模式:在组建构建过程中,某些接口之间直接的依赖常常会带来很多问题、甚至根本无法实现。采用添加一层间接(稳定)接口,来隔离本来相互紧密关联的接口是一种常见的解决方案。

  • 门面设计模式定义:为子系统中的一组接口提供一个一致(稳定)的界面,Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用(复用)。

  • 动机:

    • 上述A方案的问题在于组件的客户和组件中各种复杂的子系统有了过多的耦合,随着外部客户程序和各子系统的烟花,这种过多的耦合面临很多变化的挑战。
    • 如何简化外部客户程序和系统间的交互接口?如何将外部客户程序的烟花和内部子系统的变化之间的依赖相互解耦?
2、举例分析

在这里插入图片描述

  • 个人觉得门面设计模式是一个架构层次的设计模式,并不是一个面向对象的设计模式

  • 门面设计模式提倡:

    • 首先是接口隔离:C++中可能不太常见,写过Java程序的就知道JDBC操纵数据库是一个泛泛概念,JDBC封装了MySQL、Oracle…等数据库的操纵方式。
      • 虽然JDBC封装了很多种数据库的访问,但是它们的访问接口是统一的。这就意味着它采用了B方案,只是通过反射加载的驱动不一样,可以加载oracle、mysql的驱动,但是调用的函数api是完全一致的,这就是一个完美的接口隔离
    • 其次提倡高内聚与低耦合:高内聚的含义是Facade内部是一个高内聚的,模块与模块之间是高度内聚的存在,而对外的模块与Facade之间是一个低耦合的,因为对外的模块只需要通过Facade统一接口去操纵即可。
  • 再比如电脑:

    • 任何电脑都提供了USB、显示器、网线的接口给使用者使用,这其实就是一种门面模式,接口统一,至于我用USB连接鼠标还是连接U盘内部进行处理,反正对外就是一个统一的USB接口,机箱内部用什么主板、什么显卡、什么内存条等等都与对外的接口隔离。
3、总结
  • 从客户程序的角度来看,Facade模式简化了整个组件系统的接口,对于组件内部与外部客户程序来说,达到了一种“解耦”的效果——内部子系统的任何变化都不会影响到Facade接口的变化。

  • Facade设计模式更注重从架构的层次去看整个系统,而不是单个类的层次。Facade很多时候更是一种架构设计模式

  • Facade设计模式并非一个集装箱,可以任意地放进任何多个对象。Facade模式中组件的内部应该是“相互耦合关系比较大的一系列组件”(高内聚),而不是一个简单的功能集合。


http://www.ppmy.cn/news/1425148.html

相关文章

QML 中引用 js 文件闪退问题

问题描述 在移植 Android 中遇到这样一个引用兼容性问题,起因是这样的,Windows 版本的采用了 QML 分离的方式加载,而 Android 版本又采用了 qrc 的方式。而 Qt 中的机制是采用 QML 分离方式时则使用相对路径的方式引用 js 文件,而…

LD-Pruner、EdgeFusion(On-Device T2I)、FreeDiff、TextCenGen、MemLLM

本文首发于公众号:机器感知 https://mp.weixin.qq.com/s/KiyNfwYWU-wBiCO-hE9qkA 苏 The devil is in the object boundary: towards annotation-free instance segmentation using Foundation Models Foundation models, pre-trained on a large amount of data…

微光成束,星火燎原,酷雷曼扶持政策再升级!

从北纬 18 度的三亚海角, 到北纬 53 度的漠河不夜城, 从东经 81 度的塞外江南伊犁, 到东经 120 度的上海魔都。 酷雷曼合作商为客户服务的范围 遍及全国 300 余个地区, 跨越了东南西北的辽阔地域。 即便如此, 面…

代码随想录算法训练营第56天| 583. 两个字符串的删除操作|72. 编辑距离|编辑距离总结篇

代码随想录算法训练营第56天| 583. 两个字符串的删除操作|72. 编辑距离|编辑距离总结篇 详细布置 583. 两个字符串的删除操作 本题和动态规划:115.不同的子序列 相比,其实就是两个字符串都可以删除了,情况虽说复杂一些,但整体思…

Hotcoin4月16日上新热门资产:头部RWA技术提供方Centrifuge(CFG)

Hotcoin持续为全球600万用户发掘优质潜力资产,热门币种交易上热币。一文快速了解今日上新资产:Centrifuge(CFG) 推荐指数 8.2 交易对 CFG/USDT 交易时间 4月16日 19:00 资产赛道 RWA 项目简介 Centrifuge是一个去中心化资产融资协议,专注于释放现实世界资…

k8s中 storageclass出现错误

0/3 nodes are available: 3 pod has unbound immediate PersistentVolumeClaims. 1.在k8s中创建sc时,发现pod一直在pending状态 2.原因,在k8s 1.20版本后,由于性能影响,自动关闭了 selflink 3.解决办法 4. 在配置文件中开启selflink vim /etc/kubernetes/manifests/kube-ap…

Apache中间件漏洞

目录 什么是Apache Apache文件上传(CVE-2017-15715) Apache后缀解析 什么是Apache Apache(音译为阿帕奇)是世界使用排名第一的Web服务器软件。它可以运行在几乎所有广泛使用的计算机平台上,由于其跨平台和安全性被广泛使用,是最…

图像处理ASIC设计方法 笔记17 连通域的图像标记算法

目录 (一)主要环节图像初步标记 -等价表初始化与等价关系记录 -整理等价表 -图像标记代换 - (二)详细算法步骤:1 等价表的操作:2 整理等价表:3 图像标记代换: 连通域的图像标记算法有…