下午无聊,复习了下桥接模式,做下笔记,以后忘记了可以翻翻笔记来看看,毕竟好记性不如烂笔头。
桥接模式:将抽象和它的实现分离,使它们都可以独立变化。
假如我买了一辆skoda的小轿车,小轿车开了一段时间,现在车上得radio过时了,希望换下radio;再过段时间,上次换得radio又过时了,希望又换更接近潮流的radio。再者,skoda的车开了几年,想换量普通的大众的小轿车。上面的车和radio的关系,用我们面向对象的编程思想该怎么解决那?一般我们会想到,使用继承来实现。如用一个skoda车的类,继承自不同的radio类,在用一个VW车的类也去继承不同的radio,这样做的确可以实现,但是一旦换得radio多了,或者车的类型多了,管理取来就变的比较复杂。这时桥接模式就可以闪亮登场了,将车和radio两个类独立出来,使其可以独立变化。具体如下面UML类图:
下面是代码是代码实现:
#include <iostream> using namespace std; class Radio //表现层 { public: virtual void install() { cout<<"Radio::install()"<<endl; } }; class PqRadio : public Radio { public: virtual void install() { cout<<"PqRadio::install()"<<endl; } }; class MqbRadio : public Radio { public: virtual void install() { cout<<"MqbRadio::install()"<<endl; } }; class RowRadio : public Radio { public: virtual void install() { cout<<"RowRadio::install()"<<endl; } }; class Car //实现层 { public: virtual void configRadio(Radio* radio) { cout<<"Car::installRadio()"<<endl; radio->install(); } }; class VwCar : public Car { public: virtual void configRadio(Radio* radio) { cout<<"VwCar::configRadio()"<<endl; radio->install(); } }; class SkodaCar : public Car { public: virtual void configRadio(Radio* radio) { cout<<"SkodaCar::configRadio()"<<endl; radio->install(); } }; int main(int argc, char** argv) { Radio* radioPq = new PqRadio(); Radio* radioMqb = new MqbRadio(); Radio* radioRow = new RowRadio(); Car* car = new SkodaCar(); car->configRadio(radioPq); car->configRadio(radioRow); car->configRadio(radioMqb); delete radioPq; delete radioMqb; delete radioRow; delete car; return 0; }
输出结果如下: