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

(二)结构型模式:2、桥接模式(Bridge Pattern)(C++实现示例)

目录

1、桥接模式(Bridge Pattern)含义

2、桥接模式应用场景

3、桥接模式的UML图学习

4、C++实现桥接模式的示例


1、桥接模式(Bridge Pattern)含义

桥接模式是一种结构型设计模式,它将抽象部分与实现部分分离,使它们可以独立地变化。

2、桥接模式应用场景

1)当你希望抽象部分和实现部分可以独立地扩展和变化时,可以使用桥接模式。它可以让抽象部分和实现部分可以独立地进行演化,而不会相互影响。

2)当一个类存在多个维度的变化,且每个维度都需要独立地进行扩展时,可以考虑使用桥接模式。通过将每个维度的变化抽象为不同的继承层次结构,然后通过桥接模式将这些继承层次结构连接起来,可以灵活地组合不同的变化。

3)当需要在运行时动态地选择或切换抽象部分和实现部分的关系时,可以使用桥接模式。通过将抽象部分和实现部分解耦,并通过组合的方式建立关联,可以在运行时灵活地选择具体的实现。

4)当希望对抽象部分和实现部分进行共享和复用时,可以考虑使用桥接模式。通过将抽象部分和实现部分分离,可以使它们可以独立地进行复用,从而提高代码的可维护性和可扩展性。

总的来说,桥接模式适用于抽象部分和实现部分需要独立演化、存在多个维度的变化、需要动态选择关系或希望进行共享和复用的场景。它可以提供更好的灵活性、可扩展性和可维护性。

3、桥接模式的UML图学习

 

在上述UML类图中,有以下几个关键角色:

  • Abstraction(抽象类):定义了抽象部分的接口,并包含一个指向Implementor的成员变量。它的具体子类可以通过调用Implementor的方法来实现自己的操作。

  • Implementor(实现类接口):定义了实现部分的接口,它通常只提供了一些基本的操作方法。

  • ConcreteImplementorAConcreteImplementorB(具体实现类):实现了Implementor接口,具体实现了实现部分的操作方法。

  • RefinedAbstractionARefinedAbstractionB(扩展抽象类):继承自Abstraction,并通过调用Implementor的方法来实现自己的操作。

在桥接模式中,抽象部分和实现部分通过关联关系连接在一起,而不是继承关系。这样可以使得抽象部分和实现部分可以独立地变化和演化。

4、C++实现桥接模式的示例


#include <iostream>
#include <string>// 实现接口
class Implementor 
{
public:virtual void operationImpl() const = 0;
};// 具体实现类A
class ConcreteImplementorA : public Implementor 
{
public:void operationImpl() const override {std::cout << "ConcreteImplementorA: operationImpl" << std::endl;}
};// 具体实现类B
class ConcreteImplementorB : public Implementor 
{
public:void operationImpl() const override {std::cout << "ConcreteImplementorB: operationImpl" << std::endl;}
};// 抽象类
class Abstraction {
protected:Implementor* m_implementor;public:Abstraction(Implementor* implementor) : m_implementor(implementor) {}virtual void operation() const = 0;
};// 扩展抽象类A
class RefinedAbstractionA : public Abstraction 
{
public:RefinedAbstractionA(Implementor* implementor) : Abstraction(implementor) {}void operation() const override {std::cout << "RefinedAbstractionA: ";m_implementor->operationImpl();}
};// 扩展抽象类B
class RefinedAbstractionB : public Abstraction 
{
public:RefinedAbstractionB(Implementor* implementor) : Abstraction(implementor) {}void operation() const override {std::cout << "RefinedAbstractionB: ";m_implementor->operationImpl();}
};int main() 
{// 创建具体实现类对象Implementor* implementorA = new ConcreteImplementorA();Implementor* implementorB = new ConcreteImplementorB();// 使用扩展抽象类A调用操作Abstraction* abstractionA = new RefinedAbstractionA(implementorA);abstractionA->operation();// 使用扩展抽象类B调用操作Abstraction* abstractionB = new RefinedAbstractionB(implementorB);abstractionB->operation();delete implementorA;delete implementorB;delete abstractionA;delete abstractionB;return 0;
}

在上述示例中,我们首先定义了实现接口(Implementor),其中包含了一个纯虚函数operationImpl()。然后,我们实现了两个具体的实现类(ConcreteImplementorA和ConcreteImplementorB),它们分别继承自实现接口,并实现了接口中的纯虚函数。

接着,我们定义了抽象类(Abstraction),其中包含了一个指向实现接口的指针,并声明了一个纯虚函数operation()。然后,我们通过扩展抽象类A(RefinedAbstractionA)和扩展抽象类B(RefinedAbstractionB)来实现具体的抽象类,它们分别继承自抽象类,并实现了抽象类中的纯虚函数。

在主函数中,我们创建了具体的实现类对象(implementorA和implementorB),然后通过扩展抽象类A和扩展抽象类B来调用操作。在调用操作时,实际上会调用到具体的实现类中的具体函数。

http://www.lryc.cn/news/127202.html

相关文章:

  • FPGA_学习_16_IP核_ROM
  • 机器学习---对数几率回归
  • 网络通信原理IP头部格式(第四十二课)
  • Flink多流处理之join(关联)
  • LeetCode Top100 Liked 题单(序号34~51)
  • 视觉slam十四讲---第一弹三维空间刚体运动
  • 手把手教你配置Jenkins自动化邮件通知
  • Arcgis连续数据的分类(求不同值域的面积)
  • C++ 函数
  • 关于如何创建一个windows窗口的exe文件
  • re学习(33)攻防世界-secret-galaxy-300(动态调试)
  • springboot工程集成前端编译包,用于uni-app webView工程,解决其需独立部署带来的麻烦,场景如页面->画布->图片->pdf
  • NeuralNLP-NeuralClassifier的使用记录(二),训练预测自己的【中文文本多分类】
  • express学习笔记8 - 文件上传 下载以及预览
  • Python系统学习1-9-类(一)
  • 什么是公网、私网、内网、外网?
  • 一篇文章教会你搭建私人kindle图书馆,并内网穿透实现公网访问
  • 好用的安卓手机投屏到mac分享
  • df -h
  • 彻底卸载Android Studio
  • QT 5.12配置OpenCV3.4.10
  • Qt应用开发(基础篇)——选项卡窗口 QTabWidget
  • Socks5代理在多线程爬虫中的应用
  • 机器学习笔记:主动学习(Active Learning)初探
  • linux github 仓库管理常用操作
  • IT运维:使用数据分析平台监控深信服防火墙
  • 深入解析 Axios Blob 的使用方法及技巧
  • 爬虫逆向实战(十三)--某课网登录
  • 4.SpringCloud
  • OLED透明屏采购指南:如何选择高质量产品?