加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

浅谈设计模式之六——Bridge模式

发布时间:2020-12-13 22:28:26 所属栏目:百科 来源:网络整理
导读:先上uml图: uml解析:桥接模式讲的就是一个解耦的问题,将抽象与实现分离开来,对接口编程,使得RefinedAbstraction对实现依赖,而不是实现依赖于RefinedAbstraction,符合依赖倒置原则。 下面给出可执行代码: Bridge.h # pragma once #include iostream u

先上uml图:

uml解析:桥接模式讲的就是一个解耦的问题,将抽象与实现分离开来,对接口编程,使得RefinedAbstraction对实现依赖,而不是实现依赖于RefinedAbstraction,符合依赖倒置原则。
下面给出可执行代码:
Bridge.h

#pragma once
#include <iostream>
using namespace std;

class AbtractionImplement;

class Abtraction
{
public:
    Abtraction(void);
    virtual ~Abtraction(void);

    virtual void operation() =0;
};

class RefinedAbstraction:public Abtraction
{
public:
    RefinedAbstraction(AbtractionImplement &Imp);
    void operation();
private:
    AbtractionImplement & m_Imp;
};

class AbtractionImplement
{
public:
    virtual void operation()=0;

};

class AbtractionImplementA:public AbtractionImplement
{
public:
    void operation();

};

class AbtractionImplementB:public AbtractionImplement
{
public:
    void operation();
};

Bridge.cpp

#include "Abtraction.h"

Abtraction::Abtraction(void)
{
}

Abtraction::~Abtraction(void)
{
}

RefinedAbstraction::RefinedAbstraction(AbtractionImplement &Imp):m_Imp(Imp)
{

}

void RefinedAbstraction::operation()
{
    m_Imp.operation();
}

void AbtractionImplementA::operation()
{
    cout<<"AbtractionImplementA"<<endl;
}

void AbtractionImplementB::operation()
{
    cout<<"AbtractionImplementB"<<endl;
}

main.cpp

#include "Abtraction.h"

int main(int argc,char **argv)
{
    AbtractionImplementA impA;
    Abtraction *f1 = new RefinedAbstraction(impA);
    f1->operation();

    delete f1;
    AbtractionImplementB impB;
    f1 = new RefinedAbstraction(impB);
    f1->operation();

    return 0;
}

执行之后的结果:

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读