桥接模式通过分离抽象与实现使其独立变化,C++中以接口类定义实现并由抽象类持其指针,实现动态切换与解耦。

桥接模式的核心是把抽象部分和实现部分分离,让它们可以独立变化。在C++中,这通常通过将“实现”抽象为一个接口类,并在“抽象”类中持有该接口的指针来实现。这样,修改实现不会影响抽象的使用,也能动态切换不同的实现。
定义实现接口(Implementor)
先定义一个实现类的基类,它提供底层操作的接口:
class Implementor {public: virtual ~Implementor() = default; virtual void operationImpl() = 0;};
比如有两个具体实现:
class ConcreteImplementorA : public Implementor {public: void operationImpl() override { std::cout << "ConcreteImplementorA operationn"; }};class ConcreteImplementorB : public Implementor {void operationImpl() override {std::cout << "ConcreteImplementorB operationn";}};
定义抽象类(Abstraction)
抽象类持有一个指向实现的指针,并通过它调用实际操作:
立即学习“C++免费学习笔记(深入)”;
class Abstraction {protected: Implementor* impl;public:Abstraction(Implementor* i) : impl(i) {}
virtual ~Abstraction() = default;virtual void operation() { impl->operationImpl();}void setImplementor(Implementor* i) { impl = i;}
};
可以扩展抽象类而不影响实现:
class RefinedAbstraction : public Abstraction {public: RefinedAbstraction(Implementor* i) : Abstraction(i) {}void operation() override { std::cout <operationImpl();}
};
使用示例
客户端代码可以灵活组合抽象和实现:
int main() { Implementor* implA = new ConcreteImplementorA(); Implementor* implB = new ConcreteImplementorB();Abstraction* abs = new RefinedAbstraction(implA);abs->operation(); // 输出:RefinedAbstraction: ConcreteImplementorA operationabs->setImplementor(implB);abs->operation(); // 输出:RefinedAbstraction: ConcreteImplementorB operationdelete implA;delete implB;delete abs;return 0;
}
这种结构让“类的继承体系”和“实现方式”解耦。比如你可以新增一个 ConcreteImplementorC 而不需要改动任何抽象类,也可以增加新的抽象子类而无需修改实现。
关键点总结:
实现与抽象分离,各自独立扩展避免类爆炸:不用为每种组合写一个子类运行时可切换实现使用组合而非继承来连接抽象和实现
基本上就这些。桥接模式适合在有多维度变化、且希望保持扩展灵活性的场景中使用。
以上就是C++怎么实现一个桥接设计模式_C++结构型模式与实现和抽象分离的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1485165.html
微信扫一扫
支付宝扫一扫