桥接模式:解耦抽象与实现,实现灵活多变的扩展结构
文章目录
- 一、引言
- 二、应用场景与技术背景
- 三、模式定义与实现
- 四、实例详解
- 五、优缺点分析
- 总结:
一、引言
桥接模式是一种结构型设计模式,它将抽象部分与它的实现部分分离,使它们可以独立变化。这种模式通过创建一个抽象层和实现层的结构,并使用组合而非继承来关联这两层,从而使得系统在面对多维度变化时,能够保持较低的耦合度,支持灵活扩展。
二、应用场景与技术背景
桥接模式适用于以下场景:
- 系统需要在多个维度上进行扩展,而这些维度的变化是相互独立的。
- 不希望使用继承来实现组件间的组合,因为这会导致类爆炸或过度耦合。
例如,在图形用户界面(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&…...
龙虎榜——20250610
上证指数放量收阴线,个股多数下跌,盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型,指数短线有调整的需求,大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的:御银股份、雄帝科技 驱动…...
挑战杯推荐项目
“人工智能”创意赛 - 智能艺术创作助手:借助大模型技术,开发能根据用户输入的主题、风格等要求,生成绘画、音乐、文学作品等多种形式艺术创作灵感或初稿的应用,帮助艺术家和创意爱好者激发创意、提高创作效率。 - 个性化梦境…...
1688商品列表API与其他数据源的对接思路
将1688商品列表API与其他数据源对接时,需结合业务场景设计数据流转链路,重点关注数据格式兼容性、接口调用频率控制及数据一致性维护。以下是具体对接思路及关键技术点: 一、核心对接场景与目标 商品数据同步 场景:将1688商品信息…...
c++ 面试题(1)-----深度优先搜索(DFS)实现
操作系统:ubuntu22.04 IDE:Visual Studio Code 编程语言:C11 题目描述 地上有一个 m 行 n 列的方格,从坐标 [0,0] 起始。一个机器人可以从某一格移动到上下左右四个格子,但不能进入行坐标和列坐标的数位之和大于 k 的格子。 例…...
多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验
一、多模态商品数据接口的技术架构 (一)多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如,当用户上传一张“蓝色连衣裙”的图片时,接口可自动提取图像中的颜色(RGB值&…...
将对透视变换后的图像使用Otsu进行阈值化,来分离黑色和白色像素。这句话中的Otsu是什么意思?
Otsu 是一种自动阈值化方法,用于将图像分割为前景和背景。它通过最小化图像的类内方差或等价地最大化类间方差来选择最佳阈值。这种方法特别适用于图像的二值化处理,能够自动确定一个阈值,将图像中的像素分为黑色和白色两类。 Otsu 方法的原…...
《通信之道——从微积分到 5G》读书总结
第1章 绪 论 1.1 这是一本什么样的书 通信技术,说到底就是数学。 那些最基础、最本质的部分。 1.2 什么是通信 通信 发送方 接收方 承载信息的信号 解调出其中承载的信息 信息在发送方那里被加工成信号(调制) 把信息从信号中抽取出来&am…...
如何将联系人从 iPhone 转移到 Android
从 iPhone 换到 Android 手机时,你可能需要保留重要的数据,例如通讯录。好在,将通讯录从 iPhone 转移到 Android 手机非常简单,你可以从本文中学习 6 种可靠的方法,确保随时保持连接,不错过任何信息。 第 1…...
学习STC51单片机31(芯片为STC89C52RCRC)OLED显示屏1
每日一言 生活的美好,总是藏在那些你咬牙坚持的日子里。 硬件:OLED 以后要用到OLED的时候找到这个文件 OLED的设备地址 SSD1306"SSD" 是品牌缩写,"1306" 是产品编号。 驱动 OLED 屏幕的 IIC 总线数据传输格式 示意图 …...
Caliper 配置文件解析:fisco-bcos.json
config.yaml 文件 config.yaml 是 Caliper 的主配置文件,通常包含以下内容: test:name: fisco-bcos-test # 测试名称description: Performance test of FISCO-BCOS # 测试描述workers:type: local # 工作进程类型number: 5 # 工作进程数量monitor:type: - docker- pro…...
