设计模式之中介者模式

定义

中介者模式定义一个对象,该对象封装了其他多个对象之间如何相互作用。中介者使得多个对象之间不需要显式的相互调用。举个现实生活中的例子来说,房屋中介大家都不陌生,很多情况下我们租房子不会与屋主直接沟通,而是找中介,然后中介与屋主协商,这里的房屋中介就相当于一个中介者对象,它负责协调租房者和屋主的行为。

类和对象的关系

  • Mediator(抽象中介者):定义一个接口用于与各同事对象之间通信;
  • ConcreteMediator(具体中介者):协调各个同事对象实现协作的行为;
  • Colleague(同事类):每一个同事对象都引用一个中介者对象,当该同事对象需要和其他同事对象通信时,就与他的中介者通信。

举例说明

聊天室是中介者模式的一种应用。很多参与者进入聊天室,那么这个聊天室就是各个参与者交流的中介。通过它,参与者可以给其他参与者发送信息进行交流。这里的聊天室就是中介者对象,各个参与者就是同事对象,当参与者之间要通信时,就与它的中介者——聊天室通信,下面我们用C++来简单实现这个过程:

#include <iostream>
#include <string>
#include <map>
using namespace std;
class Parti;

class Abs_Chatroom    //抽象中介者类
{
public:
	virtual void reg(Parti *p) = 0;
	virtual bool send (const string &from, const string &to, const string &mes) = 0;
};

class ChatRoom : public Abs_Chatroom      //具体中介者 —————— 聊天室
{
public:
	void reg (Parti *p);
	bool send (const string &from, const string &to, const string &mes);
	
private:
	map<string, ChatRoom *> participates;
};

class Parti             //参与者基类
{
public:   
	Parti (string n) : name(n), chatroom(NULL){}
	string getname() const
	{
		return name;
	}
	ChatRoom **getCR ()
	{
		return &chatroom;
	}

	bool par_send(const string &to, const string &mes)    //消息的发送
	{
		return chatroom -> send (this -> name, to, mes);
	}

	void receive (const string &from, string mes)
	{
		cout << "from " << from << " to " << this -> name << " message: " << mes << endl;
	}
private:
	string name;
	ChatRoom *chatroom;
};

void ChatRoom :: reg (Parti *p)
{
	participates[p->getname()] = this;
	ChatRoom **q = p -> getCR();    
	*q = this;
}

bool ChatRoom :: send (const string &from, const string &to, const string &mes)
{
	//先检查这个人是否存在
	map<string, ChatRoom *> :: iterator iter = participates.find (to);
	if (iter == participates.end())
	{
		cout << "from " << from << " to " << to << "不存在" << endl;
		return false;
	}

	Parti pto = to;
	pto.receive(from, mes);
	return true;
}


int main()
{
	ChatRoom *newroom = new ChatRoom();
	Parti *p1 = new Parti("张三");
	Parti *p2 = new Parti("李四");
	Parti *p3 = new Parti ("王五");

	newroom -> reg (p1);
	newroom -> reg(p2);
	newroom -> reg(p3);

	p1 -> par_send("李四", "你好,我是张三");
	p2 -> par_send ("王五", "你好,我是李四");
	p3 -> par_send ("张三", "你好,我是王五");
	p3 -> par_send("李明", "你好,我是王五");

	delete p3;
	delete p2;
	delete p1;
	delete newroom;

	cout << endl;
	return 0;
}

运行结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值