桥接模式:解耦抽象与实现,实现灵活多变的扩展结构
文章目录
- 一、引言
- 二、应用场景与技术背景
- 三、模式定义与实现
- 四、实例详解
- 五、优缺点分析
- 总结:
一、引言
桥接模式是一种结构型设计模式,它将抽象部分与它的实现部分分离,使它们可以独立变化。这种模式通过创建一个抽象层和实现层的结构,并使用组合而非继承来关联这两层,从而使得系统在面对多维度变化时,能够保持较低的耦合度,支持灵活扩展。
二、应用场景与技术背景
桥接模式适用于以下场景:
- 系统需要在多个维度上进行扩展,而这些维度的变化是相互独立的。
- 不希望使用继承来实现组件间的组合,因为这会导致类爆炸或过度耦合。
例如,在图形用户界面(GUI)库中,窗口有多种外观(如Windows风格、Mac风格),同时又有多种操作(如打开、关闭、最大化等)。桥接模式可以帮助我们将窗口外观和窗口操作这两个独立变化的维度进行解耦,让每种外观都能轻松搭配不同的操作实现。
三、模式定义与实现
桥接模式的核心组成部分包括:

- Abstraction(抽象化角色):定义抽象接口,维持一个指向Implementor对象的引用。
- RefinedAbstraction(具体抽象化角色):是Abstraction接口的一个实现,负责调用Implementor对象的方法并提供额外的功能。
- Implementor(实现化角色):定义实现化角色的接口,供Abstraction角色调用。
- ConcreteImplementor(具体实现化角色):实现了Implementor接口,提供了具体的实现。
四、实例详解
以打印机系统为例,品牌属于抽象实现,彩色打印、黑白打印 属于具体实现。
- 定义抽象化角色(Abstraction):首先创建一个表示打印机的抽象类
Printer,该类包含一个指向打印技术实现对象的引用,并声明了print()方法。
public abstract class Printer {protected PrintTechnology technology;public void setPrintTechnology(PrintTechnology technology) {this.technology = technology;}// 抽象方法,由子类具体实现public abstract void print();
}
- 定义具体抽象化角色(Refined Abstraction):创建具体的打印机品牌如
HPPrinter作为Printer的子类,它实现了print()方法,在调用打印功能时,会委托给关联的打印技术对象执行实际打印操作。
public class HPPrinter extends Printer {@Overridepublic void print() {System.out.println("HP 打印机开始工作");technology.print(); // 调用实现化角色的方法}
}
- 定义实现化角色接口(Implementor):创建一个表示打印技术的接口
PrintTechnology,声明了print()方法,为各种不同的打印技术提供统一的接口。
public interface PrintTechnology {void print();
}
- 定义具体实现化角色(Concrete Implementor):分别创建两种具体的打印技术实现类,如
BlackAndWhitePrintTechnology和ColorPrintTechnology,它们都实现了PrintTechnology接口,提供了黑白打印和彩色打印的具体实现。
public class BlackAndWhitePrintTechnology implements PrintTechnology {@Overridepublic void print() {System.out.println("正在进行黑白打印...");}
}public class ColorPrintTechnology implements PrintTechnology {@Overridepublic void print() {System.out.println("正在进行彩色打印...");}
}
- 应用端使用:在应用程序中,根据需求动态组合不同的打印机品牌与打印技术。例如,可以创建一个HP品牌的打印机并设置其打印技术为黑白或彩色。
public class BridgePatternDemo {public static void main(String[] args) {Printer hpPrinter = new HPPrinter();// 设置打印技术为黑白打印hpPrinter.setPrintTechnology(new BlackAndWhitePrintTechnology());hpPrinter.print(); // 输出:HP 打印机开始工作\n正在进行黑白打印...System.out.println("===================");// 更改为彩色打印技术hpPrinter.setPrintTechnology(new ColorPrintTechnology());hpPrinter.print(); // 输出:HP 打印机开始工作\n正在进行彩色打印...}
}
测试结果

通过以上步骤,桥接模式成功地将打印机的品牌(抽象化角色)与其支持的打印技术(实现化角色)解耦合,使得二者可以独立扩展而互不影响。在实际运行时,可以根据需要灵活配置打印机的品牌和打印技术,实现不同维度的组合变化。
五、优缺点分析
优点:
- 降低耦合:通过将抽象与实现分离,消除了抽象与实现之间的静态绑定关系,使得两者可以独立改变而不影响对方。
- 提高灵活性:新增或修改抽象化角色和实现化角色的子类时,不会对其他子类造成影响,增强了系统的可扩展性。
潜在挑战:
- 复杂性增加:引入了更多的类和层次结构,可能增加理解与维护成本。
- 过度设计风险:如果需求中不存在独立变化的维度,强行使用桥接模式可能导致设计过于复杂。
总结:
桥接模式通过分离抽象与实现,为系统提供了更加灵活的设计结构,使得系统可以在多个维度上自由扩展。在实际应用中,合理运用桥接模式能有效解决因继承带来的紧耦合问题,提升代码的复用性和可维护性,尤其适用于那些需要应对多维度变化需求的软件设计。然而,也应注意避免在简单系统中过度设计,确保模式的应用符合实际需求和场景特点。
相关文章:
桥接模式:解耦抽象与实现,实现灵活多变的扩展结构
文章目录 一、引言二、应用场景与技术背景三、模式定义与实现四、实例详解五、优缺点分析总结: 一、引言 桥接模式是一种结构型设计模式,它将抽象部分与它的实现部分分离,使它们可以独立变化。这种模式通过创建一个抽象层和实现层的结构&…...
HUAWEI Programming Contest 2024(AtCoder Beginner Contest 342)
D - Square Pair 题目大意 给一长为的数组,问有多少对,两者相乘为非负整数完全平方数 解题思路 一个数除以其能整除的最大的完全平方数,看前面有多少个与其余数相同的数,两者乘积满足条件(已经是完全平方数的部分无…...
Heap sorting
堆排序比较特殊,采用数组表示堆。 先将数组表示成大根堆或者小根堆。然后从堆中依次取根,最后形成有序序列。 #include<bits/stdc.h> using namespace std;const int N 1e5 10; int a[N];void bigheap(int* a, int start, int len) {if(start …...
开源模型应用落地-qwen2模型小试-入门篇(六)
一、前言 经过前五篇“qwen模型小试”文章的学习,我们已经熟练掌握qwen大模型的使用。然而,就在前几天开源社区又发布了qwen1.5版本,它是qwen2模型的测试版本。在基于transformers的使用方式上有较大的调整,现在,我们赶紧跟上脚步,去体验一下新版本模型的推理质量。 二、…...
c#程序,oracle使用Devart驱动解决第第三方库是us7ascii,数据乱码的问题
最近做项目,要跟对方系统的库进行读写,结果发现对方采用的是oracle的us7ascii编码,我们系统默认采用的是ZHS16GBK,导致我们客户端读取和写入对方库的数据都是乱码,搜索网上,发现需要采用独立的oracle驱动去…...
代码随想录算法训练营第四一天 | 背包问题
目录 背包问题01背包二维dp数组01背包一维 dp 数组(滚动数组)分割等和子集 LeetCode 背包问题 01背包 有n件物品和一个最多能背重量为 w 的背包,第i件物品的重量是weight[i],得到的价值是value[i] 。每件物品只能用一次&#x…...
AIDL的工作原理与使用示例 跨进程通信 远程方法调用RPC
AIDL的介绍与使用 AIDL(Android Interface Definition Language)是Android中用于定义客户端和服务端之间通信接口的一种接口定义语言。它允许你定义客户端和服务的通信协议,用于在不同的进程间或同一进程的不同组件间进行数据传递。AIDL通过…...
K8S部署Java项目 pod报错 logs日志内容:no main manifest attribute, in app.jar
天行健,君子以自强不息;地势坤,君子以厚德载物。 每个人都有惰性,但不断学习是好好生活的根本,共勉! 文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。…...
SQL实现模糊查询的四种方法总结
目录 一、一般模糊查询 二、利用通配符查询 1. _ 表示任意的单个字符 2. % 表示匹配任意多个任意字符 3. [ ]表示筛选范围 4. 查询包含通配符的字符串 一、一般模糊查询 1. 单条件查询 //查询所有姓名包含“张”的记录select * from student where name like 张 2. 多条…...
爬虫基本库的使用(urllib库的详细解析)
学习爬虫,其基本的操作便是模拟浏览器向服务器发出请求,那么我们需要从哪个地方做起呢?请求需要我们自己构造吗? 我们需要关心请求这个数据结构怎么实现吗? 需要了解 HTTP、TCP、IP层的网络传输通信吗? 需要知道服务器如何响应以及响应的原理吗? 可…...
【PyQt5桌面应用开发】3.Qt Designer快速入门(控件详解)
一、Qt Designer简介 Qt Designer是PyQt程序UI界面的实现工具,可以帮助我们快速开发 PyQt 程序的速度。它生成的 UI 界面是一个后缀为 .ui 的文件,可以通过 pyiuc 转换为 .py 文件。 Qt Designer工具使用简单,可以通过拖拽和点击完成复杂界面…...
react useMemo 用法
1,useCallback 的功能完全可以由 useMemo 所取代,如果你想通过使用 useMemo 返回一个记忆函数也是完全可以的。 usecallback(fn,inputs)is equivalent to useMemo(()> fn, inputs). 区别是:useCallback不会执行第一个参数函数,而是将它返…...
python学习笔记 - 标准库函数
概述 为了方便程序员快速编写Python脚本程序,Python提供了很多好用的功能模块,它们内置于Python系统,也称为内置函数(Built-in Functions,BlF),Python 内置函数是 Python 解释器提供的一组函数,无需额外导…...
校招失败后,在小公司熬了 2 年终于进了字节跳动,竭尽全力....
其实两年前校招的时候就往字节投了一次简历,结果很明显凉了,随后这个理想就被暂时放下了,但是这个种子一直埋在心里这两年除了工作以外,也会坚持写博客,也因此结识了很多优秀的小伙伴,从他们身上学到了特别…...
PYTHON-使用正则表达式进行模式匹配
目录 Python 正则表达式Finding Patterns of Text Without Regular ExpressionsFinding Patterns of Text with Regular ExpressionsCreating Regex ObjectsMatching Regex ObjectsReview of Regular Expression MatchingMore Pattern Matching with Regular ExpressionsGroupi…...
Fiddler工具 — 19.Fiddler抓包HTTPS请求(二)
5、查看证书是否安装成功 方式一: 点击Tools菜单 —> Options... —> HTTPS —> Actions 选择第三项:Open Windows Certificate Manager打开Windows证书管理器。 打开Windows证书管理器,选择操作—>查看证书,在搜索…...
架构设计:流式处理与实时计算
引言 随着大数据技术的不断发展,流式处理和实时计算在各行各业中变得越来越重要。那么什么是流式处理呢?我们又该怎么使用它?流式处理允许我们对数据流进行实时分析和处理,而实时计算则使我们能够以低延迟和高吞吐量处理数据。本…...
Linux系统安装zookeeper
Linux安装zookeeper 安装zookeeper之前需要安装jdk,确认jdk环境没问题之后再开始安装zookeeper 下载zookeeper压缩包,官方下载地址:Apache Download Mirrors 将zookeeper压缩包拷贝到Linux并解压 # (-C 路径)可以解压到指定路径 tar -zxv…...
【前端素材】推荐优质后台管理系统Modernize平台模板(附源码)
一、需求分析 后台管理系统是一种用于管理和控制网站、应用程序或系统后台操作的软件工具,通常由授权用户(如管理员、编辑人员等)使用。它提供了一种用户友好的方式来管理网站或应用程序的内容、用户、数据等方面的操作,并且通常…...
二、Vue组件化编程
2、Vue组件化编程 2.1 非单文件组件 <div id"root"><school></school><hr><student></student> </div> <script type"text/javascript">//创建 school 组件const school Vue.extend({template: <div&…...
铭豹扩展坞 USB转网口 突然无法识别解决方法
当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…...
变量 varablie 声明- Rust 变量 let mut 声明与 C/C++ 变量声明对比分析
一、变量声明设计:let 与 mut 的哲学解析 Rust 采用 let 声明变量并通过 mut 显式标记可变性,这种设计体现了语言的核心哲学。以下是深度解析: 1.1 设计理念剖析 安全优先原则:默认不可变强制开发者明确声明意图 let x 5; …...
【HarmonyOS 5.0】DevEco Testing:鸿蒙应用质量保障的终极武器
——全方位测试解决方案与代码实战 一、工具定位与核心能力 DevEco Testing是HarmonyOS官方推出的一体化测试平台,覆盖应用全生命周期测试需求,主要提供五大核心能力: 测试类型检测目标关键指标功能体验基…...
MMaDA: Multimodal Large Diffusion Language Models
CODE : https://github.com/Gen-Verse/MMaDA Abstract 我们介绍了一种新型的多模态扩散基础模型MMaDA,它被设计用于在文本推理、多模态理解和文本到图像生成等不同领域实现卓越的性能。该方法的特点是三个关键创新:(i) MMaDA采用统一的扩散架构…...
成都鼎讯硬核科技!雷达目标与干扰模拟器,以卓越性能制胜电磁频谱战
在现代战争中,电磁频谱已成为继陆、海、空、天之后的 “第五维战场”,雷达作为电磁频谱领域的关键装备,其干扰与抗干扰能力的较量,直接影响着战争的胜负走向。由成都鼎讯科技匠心打造的雷达目标与干扰模拟器,凭借数字射…...
Unity | AmplifyShaderEditor插件基础(第七集:平面波动shader)
目录 一、👋🏻前言 二、😈sinx波动的基本原理 三、😈波动起来 1.sinx节点介绍 2.vertexPosition 3.集成Vector3 a.节点Append b.连起来 4.波动起来 a.波动的原理 b.时间节点 c.sinx的处理 四、🌊波动优化…...
2023赣州旅游投资集团
单选题 1.“不登高山,不知天之高也;不临深溪,不知地之厚也。”这句话说明_____。 A、人的意识具有创造性 B、人的认识是独立于实践之外的 C、实践在认识过程中具有决定作用 D、人的一切知识都是从直接经验中获得的 参考答案: C 本题解…...
HarmonyOS运动开发:如何用mpchart绘制运动配速图表
##鸿蒙核心技术##运动开发##Sensor Service Kit(传感器服务)# 前言 在运动类应用中,运动数据的可视化是提升用户体验的重要环节。通过直观的图表展示运动过程中的关键数据,如配速、距离、卡路里消耗等,用户可以更清晰…...
CVE-2020-17519源码分析与漏洞复现(Flink 任意文件读取)
漏洞概览 漏洞名称:Apache Flink REST API 任意文件读取漏洞CVE编号:CVE-2020-17519CVSS评分:7.5影响版本:Apache Flink 1.11.0、1.11.1、1.11.2修复版本:≥ 1.11.3 或 ≥ 1.12.0漏洞类型:路径遍历&#x…...
虚拟电厂发展三大趋势:市场化、技术主导、车网互联
市场化:从政策驱动到多元盈利 政策全面赋能 2025年4月,国家发改委、能源局发布《关于加快推进虚拟电厂发展的指导意见》,首次明确虚拟电厂为“独立市场主体”,提出硬性目标:2027年全国调节能力≥2000万千瓦࿰…...
