中介者模式(Mediator)
GOF:用一个中介对象来封装一系列的对象交互。中介者使对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。
类图:
适用性:
- 一组对象以定义良好但是复杂的方式进行通信。因为这组类之间的相互关系错综复杂,如果直接管理会十分困难,因此利用中介者管理它们的关系,而Client只需要知道中介者的接口即可。
- 一个对象引用其他很多对象并且直接与这些对象通信,导致难以复用该对象。
- 想定制一个分布在多个类中的行为,而又不想生成太多的子类。
优缺:
- 减少了子类的生成。
- 它将各Colleague解耦。
- 它简化了对象协议。由多对多变成一对多。
- 它对对象如何写作进行了抽象。将注意力从对象各自本身的行为转移到它们之间的交互上来。
- 它使控制集中化。将对象间交互的复杂性变为中介者的复杂性,可能使得中介者自身成为一个难于维护的庞然大物。
模板代码:
#include <iostream>
#include <string>
using namespace std;
class Colleague;
class Mediator {
public:
;
};
class Colleague {
public:
Colleague(Mediator *pMediator) { m_pMediator = pMediator; }
void notify(string message) { cout << "Got message : " << message << endl; }
protected:
Mediator *m_pMediator;
};
class ConcreteColleague1 : public Colleague {
public:
ConcreteColleague1(Mediator *pMediator) : Colleague(pMediator) {}
void send(string message) { m_pMediator->send(message, this); }
void notify(string message) { cout << "Colleague1 got message : " << message << endl; }
};
class ConcreteColleague2 : public Colleague {
public:
ConcreteColleague2(Mediator *pMediator) : Colleague(pMediator) {}
void send(string message) { m_pMediator->send(message, this); }
void notify(string message) { cout << "Colleague2 got message : " << message << endl; }
};
class ConcreteMediator : public Mediator {
public:
void setColleague1(ConcreteColleague1 *pColleague1) {
m_pColleague1 = pColleague1;
}
void setColleague2(ConcreteColleague2 *pColleague2) {
m_pColleague2 = pColleague2;
}
void send(string message, Colleague *pColleague) {
if(pColleague == m_pColleague1) {
m_pColleague2->notify(message);
}
else {
m_pColleague1->notify(message);
}
}
private:
ConcreteColleague1 *m_pColleague1;
ConcreteColleague2 *m_pColleague2;
};
int main() {
ConcreteMediator *pcm = new ConcreteMediator();;
ConcreteColleague1 *pc1 = new ConcreteColleague1(pcm);
ConcreteColleague2 *pc2 = new ConcreteColleague2(pcm);
pcm->setColleague1(pc1);
pcm->setColleague2(pc2);
pc1->send("message from pc1");
delete pcm; delete pc1; delete pc2;
;
}
中介者模式就是封装了多个类之间的交互,使得我们不需要直接在多个类之间手动弄交互。
如下所示:
但是这样就使得中介者变得复杂了,需要小心管理。
中介者模式(Mediator)的更多相关文章
- 【转】设计模式 ( 十五 ) 中介者模式Mediator(对象行为型)
设计模式 ( 十五 ) 中介者模式Mediator(对象行为型) 1.概述 在面向对象的软件设计与开发过程中,根据"单一职责原则",我们应该尽量将对象细化,使其只负责或呈现单一的职 ...
- 二十四种设计模式:中介者模式(Mediator Pattern)
中介者模式(Mediator Pattern) 介绍用一个中介对象来封装一系列的对象交互.中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互. 示例有一个Messa ...
- 设计模式 ( 十五 ) 中介者模式Mediator(对象行为型)
设计模式 ( 十五 ) 中介者模式Mediator(对象行为型) 1.概述 在面向对象的软件设计与开发过程中,根据“单一职责原则”,我们应该尽量将对象细化,使其只负责或呈现单一的职责,即将行为分布到各 ...
- 乐在其中设计模式(C#) - 中介者模式(Mediator Pattern)
原文:乐在其中设计模式(C#) - 中介者模式(Mediator Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 中介者模式(Mediator Pattern) 作者:weba ...
- 中介者模式(Mediator Pattern)
用于减少多个对象或类之间的通信复杂性. 此模式提供了一个中介类,它通常处理不同类之间的所有通信,并支持通过松散耦合来维护代码.中介者模式属于行为模式类别. 实现实例 在这里通过一个聊天室的示例来演示中 ...
- 设计模式系列之中介者模式(Mediator Pattern)——协调多个对象之间的交互
说明:设计模式系列文章是读刘伟所著<设计模式的艺术之道(软件开发人员内功修炼之道)>一书的阅读笔记.个人感觉这本书讲的不错,有兴趣推荐读一读.详细内容也可以看看此书作者的博客https:/ ...
- 18.中介者模式(Mediator Pattern)
using System; namespace Test { class Program { /// <summary> /// 中介者模式,定义了一个中介对象来封装一系列对象之间的交互关 ...
- 大熊君说说JS与设计模式之------中介者模式Mediator
一,总体概要 1,笔者浅谈 我们从日常的生活中打个简单的比方,我们去房屋中介租房,房屋中介人在租房者和房东出租者之间形成一条中介.租房者并不关心他租谁的房.房东出租者也不关心他租给谁.因为有中介的存在 ...
- 设计模式-中介者模式(Mediator)
场景分析: 众所周知,电脑有很多组成部分,如硬盘.内存.光驱.音频.键盘等,各个组件之间协同工作才能保证电脑的正常运行. 如果各个组件之间直接交互,可能会比较复杂,如下图: 将上面的各个组件抽象成类, ...
随机推荐
- unicode-range 字体混搭(转)
最先想到的方法是定义两个拥有不同字体CSS类分别赋予不同的元素. <div class="font1"></div> <div class=" ...
- PHP 生成二维码
利用PHP QRcode生成二维码: php QRcode 官网 http://phpqrcode.sourceforge.net/ 在官网下载 phpqrcode.php就ok啦: 然后,查看自己的 ...
- jQuery下操作dropdownlist
dropdownlist呈现到html中如下: <select id="ddlOrg" name="ddlOrg"> <option ...
- javascript选取文档元素
用指定的id属性 用指定的name属性 用指定的标签名字 用指定的CSS类 匹配指定的CSS选择器 通过ID选取元素 var section1 = document.getElementById(&q ...
- UVa12092 Paint the Roads(最小费用最大流)
题目大概说一个n个点m条带权有向边的图,要给边染色,染色的边形成若干个回路且每个点都恰好属于其中k个回路.问最少要染多少边权和的路. 一个回路里面各个点的入度=出度=1,那么可以猜想知道各个点如果都恰 ...
- HDU3157 Crazy Circuits(有源汇流量有上下界网络的最小流)
题目大概给一个电路,电路上有n+2个结点,其中有两个分别是电源和负载,结点们由m个单向的部件相连,每个部件都有最少需要的电流,求使整个电路运转需要的最少电流. 容量网络的构建很容易,建好后就是一个有源 ...
- Windows 8 系统安装
系统城 http://www.xitongcheng.com/win8/ 1. 下载 win8: http://msdn.itellyou.cn/2. 准备 4G 以上 U 盘,下载 win8 ...
- BZOJ 2882 & 后缀数组的傻逼实现
题意: 一个字符环,求一个开头使字典序最小. SOL: 后缀数组打起来...然后居然卡过...10sec的实现我10936ms...居然卡过??? rank倒三...啦啦啦啦啦.... 改个离散化会不 ...
- 使用javamail发信过程中的一些问题及解决方法
http://www.blogjava.net/TrampEagle/archive/2006/05/26/48326.html 今天在研究javamail发信的过程中,出现了一些小问题,现总结如下, ...
- BZOJ 1012 题解
1012: [JSOI2008]最大数maxnumber Time Limit: 3 Sec Memory Limit: 162 MBSubmit: 8468 Solved: 3702[Submi ...