1.意图

将抽象部分与它的实现部分分离,使它们都可以独立地变化。

2.动机

在抽象类与它的实现之间起到桥梁作用,使它们可以独立地变化。

3.适用性

  • 不希望在抽象和它的实现部分之间有一个固定的绑定关系。这种情况可能是因为,在程序运行时刻实现部分可以被选择或切换。
  • 类的抽象以及它的实现部分都应该可以通过生成子类的方式加以扩充。这时桥接模式使你可以对不同的抽象接口和实现部分进行组合,并分别对它们进行扩充。
  • 对一个抽象实现部分的修改的修改不应该对客户产生影响,即客户代码不必要重新编译。
  • 对客户完全隐藏抽象的实现部分。C++中类的表示在类接口中是可见的。
  • 有许多类要生成,这样一种类层次结构说明你必须将一个对象分解成两部分。

4.结构

5.代码实例

#include <memory>

class  AbstactionImpl;

class Abstration
{
public:
void virtual Operaion()=;
void virtual SetImpl(std::shared_ptr<AbstactionImpl>& pImpl)=;
protected: std::shared_ptr<AbstactionImpl> m_pImpl; }; class RedefinedAbstration : public Abstration
{
public:
void Operaion();
void SetImpl(std::shared_ptr<AbstactionImpl>& pImpl);
};
class AbstactionImpl
{
public:
void virtual OperationImpl()=;
}; class ConcreteImplentorA : public AbstactionImpl
{
public:
void OperationImpl();
}; class ConcreteImplentorB : public AbstactionImpl
{
public:
void OperationImpl();
};
#include "Abstration.h"
#include "Implentor.h" void RedefinedAbstration::Operaion()
{
m_pImpl->OperationImpl();
} void RedefinedAbstration::SetImpl(std::shared_ptr<AbstactionImpl>& pImpl)
{
m_pImpl = pImpl;
}
#include <iostream>
#include "Implentor.h" void ConcreteImplentorA::OperationImpl()
{
std::cout<<"ConcreteImplenorA Exectued" <<std::endl;
} void ConcreteImplentorB::OperationImpl()
{
std::cout<<"ConcreteImplentorB Exectued"<<std::endl;
}
#include <memory>
#include "Abstration.h"
#include "Implentor.h" int main()
{ std::shared_ptr<AbstactionImpl> pConcreteImplA(new ConcreteImplentorA);
std::shared_ptr<AbstactionImpl> pConcreteImplB(new ConcreteImplentorB); std::shared_ptr<RedefinedAbstration> pRedefinedAbstration(new RedefinedAbstration);
pRedefinedAbstration->SetImpl(pConcreteImplA);
pRedefinedAbstration->Operaion(); pRedefinedAbstration->SetImpl(pConcreteImplB);
pRedefinedAbstration->Operaion(); while(); }

6.测试结果

7.效果

  • 分离接口及其实现部分 一个实现未必不变地绑定在一个接口上。抽象类的实现可以在运行时刻进行配置,一个对象甚至可以在运行时刻改变它的实现。将Abstraction和Implementor分离有助于降低对实现部分编译时刻的依赖性,当改变一个实现类时,并不需要重新编译Abstaction类和它的客户程序。
  • 提高可扩充性 可以独立地对Abstraction和Implementor层次结构进行扩充。
  • 实现细节对客户透明 可以对客户隐藏实现细节。

Bridge(桥接)-对象结构型模式的更多相关文章

  1. 组合模式/composite模式/对象结构型模式

    组合模式/composite模式/对象结构型 意图 将对象组合成树形结构以表示"整体--部分"的层次结构.Composite使得用户对单个对象和组合对象的使用具有一致性. 动机 C ...

  2. Bridge模式——对象结构型模式

    今天看了Bridge模式,对其进行简单的总结,并给出几篇通俗易懂的文章链接. (一)意图--将抽象部分和它的实现部分分离,使它们都可以独立地变化. 适用于从多维度描述的类型,拆解开来,使其能沿着各维度 ...

  3. Facade(外观)-对象结构型模式

    1.意图 为子系统中的一组接口提供一个一致的接口,Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用. 2.动机 将一个系统划分成若干子系统有利于降低系统的复杂性.一个常见的设计目 ...

  4. Decorator(装饰)-对象结构型模式

    1.意图 动态地给一个对象添加一些额外的职责.就增加功能来说,Decorator模式相比生成子类更为灵活. 2.别名 包装器 Wrapper. 3.动机 给某个对象而不是整个类添加一些功能.一个较为灵 ...

  5. Adapter(适配器)-类对象结构型模式

    1.意图 将一个类接口转换成客户希望的另外一个接口.Adapter模式使那些原本不能一起工作的类,可以一起工作. 2.别名 包装器 Wrapper. 3.动机 一个应用可能会有一些类具有不同的接口,并 ...

  6. Proxy(代理)-对象结构型模式

    1.意图 为其它对象提供一种代理以控制对这个对象的访问. 2.别名 Surrogate. 3.动机 通过Proxy可以达到对一个对象的访问控制. 4.适用性 远程代理  为一个对象在不同地址空间提供局 ...

  7. Flyweight(享元)--对象结构型模式

    1.意图 运用共享技术有效地支持大量细粒度的对象. 2.动机 Flyweight模式描述了如何共享对象,使得可以细粒度地使用它们,而无需高昂的代价.flyweight是一个共享对象,它可以同时在多个场 ...

  8. Composite(组合)--对象结构型模式

    1.意图 将对象组合成树形结构以表示“部分-整体”的层次结构.Composite使得用户对单个对象和组合对象的使用具有一致性. 2.动机 可以组合多个简单组件以形成一些较大的组件,这些组件又可以组合成 ...

  9. 桥接模式(bridge pattern)-------结构型模式

    桥接模式是一种对象结构型模式,其将抽象部分和它的实现部分分离,使它们都可以独立的变化,又称为柄体(Handle and Body)模式或接口(Interface)模式. 优点: 1.分离抽象接口及其实 ...

随机推荐

  1. java Scanner

    public static void main(String[] args) throws IOException { System.out.print("Enter a number:&q ...

  2. java实现定时任务的三种方法

    /** * 普通thread * 这是最常见的,创建一个thread,然后让它在while循环里一直运行着, * 通过sleep方法来达到定时任务的效果.这样可以快速简单的实现,代码如下: * @au ...

  3. 解决wamp的Apache服务器不能重启

    由于工作需要,现在开始研究PHP语言.刚开始搭建服务器环境就困难重重啊.首先看了下配置说明,很复杂很复杂(超级想念Visual Studio).然后问了下群里的老鸟,他们都是安装WAMPServer环 ...

  4. [cross compile]cygwin和mingw

    转自:http://blog.csdn.net/embededvc/article/details/6829010 1. MinGW和CygWin/gcc概念 Unix下编译通过的C代码,在win32 ...

  5. 【MySQL】优化—工欲善其事,必先利其器之EXPLAIN

    接触MySQL已经有一段时间了,了解如何优化它也迫在眉睫了,话说工欲善其事,必先利其器.最近我就打算了解下几个优化MySQL中经常用到的工具.今天就简单介绍下EXPLAIN. 环境准备 Explain ...

  6. 短作业优先调度算法(SJF)

    假设有n项作业位于就绪队列中,这些作业的提交时间用数组requestTimes按照提交时间的先后顺序存储,对应的作业服务时间(持续时间)用数组durations存储.采用SJF算法,计算n项作业的平均 ...

  7. 使用ADD_CUSTOM_COMMAND 添加自定义命令

    e.g. ADD_CUSTOM_COMMAND(           TARGET world_server           COMMAND cp ${CMAKE_SOURCE_DIR}/CMak ...

  8. C#_GDI+详细教程(图形图像编程基础)

    第7章  C#图形图像编程基础 本章主要介绍使用C#进行图形图像编程基础,其中包括GDI+绘图基础.C#图像处理基础以及简单的图像处理技术. 7.1  GDI+绘图基础 编写图形程序时需要使用GDI( ...

  9. 转:WIN7上搭建Windows Phone 8 开发环境——VMware Workstation下Win8 “无法安装Hyper-V, 某个虚拟机监控程序正在运行”问题解决的办法

    转自:http://www.cnblogs.com/shaddock2013/p/3155024.html 最近在试着在Windows 7上搭建Windows Phone 8的开发调试环境,使用的是V ...

  10. I2C控制器的Verilog建模之二

    前言:接着上一篇的I2C写操作,今天要实现一个I2C的读操作.虽然在ADV7181B配置内部寄存器时没有必要使用到读操作,但是为了进一步确认寄存器是否在I2C写模块下被正确配置,这一步是必不可少的. ...