zoukankan      html  css  js  c++  java
  • 中介者模式(c++实现)

    中介者模式

    模式定义

    中介者模式(Mediator),用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显示地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。

    模式动机

    • 尽管讲一个系统分割成许多对象通常可以增加其可复用性,但是对象间相互连接的激增又会降低其可复用性了。大量的连接使得一个对象不可能在没有其他对象的支持下工作,系统表现为一个不可分割的整体,所以,对系统的行为进行任何较大的改动就十分困难了
    • 中介者模式一般应用于一组对象以定义良好但是复杂的方式进行通信的场合,以及想定制以一个分布在多个类中的行为,而又不想生成太多的子类的场合。

    UML类图

    源码实现

    • colleague.h
    #include <string>
    
    class Mediator;
    class Colleague
    {
    public:
        Colleague(Mediator* mediator);
        virtual ~Colleague();
        virtual void Notify(std::string message) = 0;
        void Send(std::string message);
    
    private:
        Mediator*       m_Mediator;
    };
    
    • concretecolleague.h
    #include "colleague.h"
    
    class Mediator;
    class ConcreteColleague1 : public Colleague
    {
    public:
        ConcreteColleague1(Mediator* mediator);
        void Notify(std::string message) override;
    
    private:
        Mediator*       m_Mediator;
    };
    
    • concretecolleague.cpp
    #include "colleague.h"
    
    class Mediator;
    class ConcreteColleague1 : public Colleague
    {
    public:
        ConcreteColleague1(Mediator* mediator);
        void Notify(std::string message) override;
    
    private:
        Mediator*       m_Mediator;
    };
    
    • mediator.h
    #include <string>
    class Colleague;
    class Mediator
    {
    public:
        Mediator();
        void Send(std::string message, Colleague* colleague);
    
        void SetColleague1(Colleague* colleague);
        void SetColleague2(Colleague* colleague);
    private:
        Colleague*      m_Colleague1;
        Colleague*      m_Colleague2;
    };
    
    • mediator.cpp
    #include <string>
    class Colleague;
    class Mediator
    {
    public:
        Mediator();
        void Send(std::string message, Colleague* colleague);
    
        void SetColleague1(Colleague* colleague);
        void SetColleague2(Colleague* colleague);
    private:
        Colleague*      m_Colleague1;
        Colleague*      m_Colleague2;
    };
    
    • main.cpp
    #include <iostream>
    #include "concretecolleague1.h"
    #include "concretecolleague2.h"
    #include "mediator.h"
    
    using namespace std;
    
    int main()
    {
        Mediator* mediator = new Mediator();
    
        Colleague* c1 = new ConcreteColleague1(mediator);
        Colleague* c2 = new ConcreteColleague2(mediator);
    
        mediator->SetColleague1(c1);
        mediator->SetColleague2(c2);
    
        c1->Send("吃了吗");
        c2->Send("我吃过了,你呢");
        return 0;
    }
    
    • 运行结果

    同事2得到消息:吃了吗

    同事1得到消息:我吃过了,你呢

    优点

    中介者模式的优点

    • 中介者模式很容易在系统中应用,也很容易在系统中应用。当系统出现了“多对多”交互复杂的对象群时,不要急于使用中介者模式,而要先烦死你的系统在设计上是不是合理。
    • Mediator的出现减少了各个Colleague的耦合,使得可以独立的改变和复用各个Colleague类和Mediator。由于把对象如何协作进行了抽象,将中介作为一个独立的概念并将其封装在一个对象中,这样关注的对象就从对象各自本身的行为转移到他们之间的交互上来,也就是站在一个更宏观的角度去看待系统。

    缺点

    中介者模式的缺点

    • 由于ConcreteMediator控制了集中化,于是就把交互复杂性变为了中介者的复杂性,这就使得中介者会变得比任何一个ConcreteColleague都复杂。
  • 相关阅读:
    Oracle FGA审计记录的清理步骤
    UVa11488-Hyper Prefix Sets(trie树)
    配置Log4j(非常具体)
    poj1190生日蛋糕
    zju1610Count the Colors
    【例9.3】求最长不下降序列
    P1364 医院设置
    P1629 邮递员送信
    P1476 休息中的小呆
    P1330 封锁阳光大学
  • 原文地址:https://www.cnblogs.com/wzxNote/p/13345152.html
Copyright © 2011-2022 走看看