桥接模式(Bridge Pattern)是用于把抽象化与实现化解耦,使得二者可以独立变化。这种类型的设计模式属于结构型模式,它提供抽象化和实现化的桥接结构,来实现二者的解耦。
这种模式涉及到一个作为桥接的接口,使得实体类的功能独立于接口实现类。这两种类型的类可被结构化改变而互不影响。
意图
把抽象部分与现实部分分离,使它们都可以独立的变化。(这个思想有点不好理解,多看看实例就好了)
解决问题
过多的使用继承会造成类爆炸问题,扩展起来不灵活。
如何解决
把这种多角度分类分离出来,让他们独立变化,减少他们之间的耦合。
优点
1.抽象和实现的分离
2.优秀的扩展能力
3.实现细节对客户透明
缺点
会增加系统的理解和设计难度,由于聚合关联关系建立在抽象层,要求开发者针对抽象进行设计与编程
注意事项
对于两个独立变化的维度,使用桥接模式在合适不过了
C++实现
考虑装操作系统,有多种配置的计算机,同样也有多款操作系统。如何运用桥接模式呢?
可以将操作系统和计算机分别抽象出来,让它们各自发展,减少它们的耦合度。当然了,两者之间有标准的接口。这样设计,不论是对于计算机,还是操作系统都是非常有利的。
下面给出这种设计的UML图,其实就是桥接模式的UML类图:
具体实现
//桥接模式
class Implementor //实现者
{
public :
virtual void OperationImp() = 0;
};
class Implementor1 : public Implementor
{
public :
void OperationImp()
{
cout << "OperationImp" << endl;
}
};
class Abstraction //抽象
{
protected:
Implementor* p_Imp;
public :
Abstraction(Implementor* Imp)
:p_Imp(Imp)
{}
virtual void Operation() =0 ;
};
class RedfinedAbstraction : public Abstraction
{
public :
RedfinedAbstraction(Implementor* Imp)
:Abstraction(Imp)
{}
void Operation()
{
p_Imp->OperationImp();
}
};
客户端:
int test_Bridge()
{
Implementor* pIm = new Implementor1();
Abstraction* pAbs = new RedfinedAbstraction(pIm);
pAbs->Operation();
delete pIm;
delete pAbs;
pIm = NULL;
pAbs= NULL;
system("pause");
return 0;
}
总结
桥接模式使得抽象和实现进行了分离,抽象不用依赖于实现,让抽象和实现部分各自修改起来都很方便,使用组合(就是Abstraction类中包含了Implementor)的方式,降低了耦合度,同时也有助于分层,从而产生更好的结构化系统。