


























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

#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;
};
#include "colleague.h"
class Mediator;
class ConcreteColleague1 : public Colleague
{
public:
ConcreteColleague1(Mediator* mediator);
void Notify(std::string message) override;
private:
Mediator* m_Mediator;
};
#include "colleague.h"
class Mediator;
class ConcreteColleague1 : public Colleague
{
public:
ConcreteColleague1(Mediator* mediator);
void Notify(std::string message) override;
private:
Mediator* m_Mediator;
};
#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;
};
#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;
};
#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得到消息:我吃过了,你呢
中介者模式的优点
中介者模式的缺点
此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。