java设计模式---调停者模式
//抽象同事类
abstract class AbstractColleague { protected AbstractMediator mediator; /**既然有中介者,那么每个具体同事必然要与中介者有联系, * 否则就没必要存在于 这个系统当中,这里的构造函数相当 * 于向该系统中注册一个中介者,以取得联系 */ public AbstractColleague(AbstractMediator mediator) { this.mediator = mediator; } // 在抽象同事类中添加用于与中介者取得联系(即注册)的方法 public void setMediator(AbstractMediator mediator) { this.mediator = mediator; }
} //具体同事A
class ColleagueA extends AbstractColleague { //每个具体同事都通过父类构造函数与中介者取得联系 public ColleagueA(AbstractMediator mediator) { super(mediator); } //每个具体同事必然有自己分内的事,没必要与外界相关联 public void self() { System.out.println("同事A --> 做好自己分内的事情 ..."); } //每个具体同事总有需要与外界交互的操作,通过中介者来处理这些逻辑并安排工作 public void out() { System.out.println("同事A --> 请求同事B做好分内工作 ..."); super.mediator.execute("ColleagueB", "self"); }
} //具体同事B
class ColleagueB extends AbstractColleague { public ColleagueB(AbstractMediator mediator) { super(mediator); } public void self() { System.out.println("同事B --> 做好自己分内的事情 ..."); } public void out() { System.out.println("同事B --> 请求同事A做好分内工作 ..."); super.mediator.execute("ColleagueA", "self"); }
}
中介者类族:
//抽象中介者
abstract class AbstractMediator { //中介者肯定需要保持有若干同事的联系方式 protected Hashtable<String, AbstractColleague> colleagues = new Hashtable<String, AbstractColleague>(); //中介者可以动态地与某个同事建立联系 public void addColleague(String name, AbstractColleague c) { this.colleagues.put(name, c); } //中介者也可以动态地撤销与某个同事的联系 public void deleteColleague(String name) { this.colleagues.remove(name); } //中介者必须具备在同事之间处理逻辑、分配任务、促进交流的操作 public abstract void execute(String name, String method);
} //具体中介者
class Mediator extends AbstractMediator{ //中介者最重要的功能,来回奔波与各个同事之间 public void execute(String name, String method) { if("self".equals(method)){ //各自做好分内事 if("ColleagueA".equals(name)) { ColleagueA colleague = (ColleagueA)super.colleagues.get("ColleagueA"); colleague.self(); }else { ColleagueB colleague = (ColleagueB)super.colleagues.get("ColleagueB"); colleague.self(); } }else { //与其他同事合作 if("ColleagueA".equals(name)) { ColleagueA colleague = (ColleagueA)super.colleagues.get("ColleagueA"); colleague.out(); }else { ColleagueB colleague = (ColleagueB)super.colleagues.get("ColleagueB"); colleague.out(); } } }
}
测试类:
//测试类
public class Client { public static void main(String[] args) { //创建一个中介者 AbstractMediator mediator = new Mediator(); //创建两个同事 ColleagueA colleagueA = new ColleagueA(mediator); ColleagueB colleagueB = new ColleagueB(mediator); //中介者分别与每个同事建立联系 mediator.addColleague("ColleagueA", colleagueA); mediator.addColleague("ColleagueB", colleagueB); //同事们开始工作 colleagueA.self(); colleagueA.out(); System.out.println("======================合作愉快,任务完成!\n"); colleagueB.self(); colleagueB.out(); System.out.println("======================合作愉快,任务完成!"); }
}
测试结果:
同事A --> 做好自己分内的事情 ...
同事A --> 请求同事B做好分内工作 ...
同事B --> 做好自己分内的事情 ...
======================合作愉快,任务完成! 同事B --> 做好自己分内的事情 ...
同事B --> 请求同事A做好分内工作 ...
同事A --> 做好自己分内的事情 ...
======================合作愉快,任务完成!
此外,上面这个代码例子是相当理想的了,有时候我们根本抽取不了“同事”之间的共性来形成一个AbstractColleague抽象同事类,这也大大增加了中介者模式的使用难度。
修改:
由于上面代码实现中存在 benjielin 前辈提出的“双向关联暴露在App中”的不足之处,根据给出的改进方法2,修改上面代码,如下:
修改后的同事类族:
//抽象同事类
abstract class AbstractColleague { protected AbstractMediator mediator; //舍去在构造函数中建立起与中介者的联系
// public AbstractColleague(AbstractMediator mediator) {
// this.mediator = mediator;
// } // 在抽象同事类中添加用于与中介者取得联系(即注册)的方法 public void setMediator(AbstractMediator mediator) { this.mediator = mediator; }
} //具体同事A
class ColleagueA extends AbstractColleague { //舍去在构造函数中建立起与中介者的联系
// public ColleagueA(AbstractMediator mediator) {
// super(mediator);
// } //每个具体同事必然有自己分内的事,没必要与外界相关联 public void self() { System.out.println("同事A --> 做好自己分内的事情 ..."); } //每个具体同事总有需要与外界交互的操作,通过中介者来处理这些逻辑并安排工作 public void out() { System.out.println("同事A --> 请求同事B做好分内工作 ..."); super.mediator.execute("ColleagueB", "self"); }
} //具体同事B
class ColleagueB extends AbstractColleague { //舍去在构造函数中建立起与中介者的联系
// public ColleagueB(AbstractMediator mediator) {
// super(mediator);
// } public void self() { System.out.println("同事B --> 做好自己分内的事情 ..."); } public void out() { System.out.println("同事B --> 请求同事A做好分内工作 ..."); super.mediator.execute("ColleagueA", "self"); }
}
修改后的中介者:
//抽象中介者
abstract class AbstractMediator { //中介者肯定需要保持有若干同事的联系方式 protected Hashtable<String, AbstractColleague> colleagues = new Hashtable<String, AbstractColleague>(); //中介者可以动态地与某个同事建立联系 public void addColleague(String name, AbstractColleague c) { // 在中介者这里帮助具体同事建立起于中介者的联系 c.setMediator(this); this.colleagues.put(name, c); } //中介者也可以动态地撤销与某个同事的联系 public void deleteColleague(String name) { this.colleagues.remove(name); } //中介者必须具备在同事之间处理逻辑、分配任务、促进交流的操作 public abstract void execute(String name, String method);
}
//测试类
public class Client { public static void main(String[] args) { //创建一个中介者 AbstractMediator mediator = new Mediator(); //不用构造函数为具体同事注册中介者来取得联系了
// ColleagueA colleagueA = new ColleagueA(mediator);
// ColleagueB colleagueB = new ColleagueB(mediator); ColleagueA colleagueA = new ColleagueA(); ColleagueB colleagueB = new ColleagueB(); //中介者分别与每个同事建立联系 mediator.addColleague("ColleagueA", colleagueA); mediator.addColleague("ColleagueB", colleagueB); //同事们开始工作 colleagueA.self(); colleagueA.out(); System.out.println("======================合作愉快,任务完成!\n"); colleagueB.self(); colleagueB.out(); System.out.println("======================合作愉快,任务完成!"); }
}
本文来自:http://haolloyin.blog.51cto.com/1177454/333810/
java设计模式---调停者模式相关推荐
- java备忘录模式应用场景_图解Java设计模式之备忘录模式
图解Java设计模式之备忘录模式 游戏角色状态恢复问题 游戏角色有攻击力和防御力,在大战Boss前保存自身的状态(攻击力和防御力),当大战Boss后攻击力和防御力下降,从备忘录对象恢复到大战前的状态. ...
- Java设计模式之策略模式与状态模式
一.策略模式定义 定义:策略模式定义了一系列的算法,并将每一个算法封装起来,而且使他们之间可以相互替换,策略模式可以在不影响客户端的情况下发生变化. 好了,定义看看就完了,我知道你很烦看定义. 二.策 ...
- Java设计模式(访问者模式-迭代器模式-观察者模式-中介者模式)
Java设计模式Ⅶ 1.访问者模式 1.1 访问者模式概述 1.2 代码理解 2.迭代器模式 2.1 迭代器模式概述 2.2 代码理解 3.观察者模式 3.1 观察者模式概述 3.2 代码理解 4.中 ...
- Java设计模式(建造者模式-适配器模式-桥接模式)
Java设计模式Ⅲ 1.建造者模式 1.1 建造者模式概述 1.2 建造者模式的注意事项和细节 1.3 代码理解 2.适配器模式 2.1 类适配器模式 2.1.1 代码理解 2.2 对象适配器模式 2 ...
- Java设计模式(工厂模式>抽象工厂模式和原型模式)
Java设计模式Ⅱ 1.工厂模式 1.1 简单工厂模式 1.2 工厂方法模式 2.抽象工厂模式 3.总结 4.原型模式 4.1 原型模式 4.2 浅拷贝 4.3 深拷贝 5.建造者模式 1.工厂模式 ...
- 折腾Java设计模式之建造者模式
博文原址:折腾Java设计模式之建造者模式 建造者模式 Separate the construction of a complex object from its representation, a ...
- java设计模式6--适配器模式(Adapter )
本文地址:http://www.cnblogs.com/archimedes/p/java-adapter-pattern.html,转载请注明源地址. 适配器模式(别名:包装器) 将一个类的接口转换 ...
- java设计模式5--原型模式(Prototype)
本文地址:http://www.cnblogs.com/archimedes/p/java-prototype-pattern.html,转载请注明源地址. 原型模式 用原型实例指定创建对象的种类,并 ...
- java设计模式3--单例模式(Singleton)
本文地址:http://www.cnblogs.com/archimedes/p/java-singleton-pattern.html,转载请注明源地址. 单例模式 保证一个类仅有一个实例,并提供一 ...
最新文章
- 比较分析 Spring AOP 和 AspectJ 之间的差别
- mvc4 ajax url参数,MVC4.0中Ajax通过a标签向后台Action传递参数问题?
- 为什么要使用React Hooks?(5分钟实例)
- c语言如何编写mysql客户端_【C/C++学院】(23)Mysql数据库编程--C语言编程实现mysql客户端...
- 摘抄一篇:图的存储结构
- 《MYSQL必知必会》— 14~17.子查询、联结、高级联结、组合查询
- OSPF区域间路由计算规则与实验
- Spring,Mybatis,Springmvc框架整合项目(第一部分)
- 《长安十二时辰》带来的启示:行走江湖,数据泄露怎能不防?
- 视频实现blob加密
- 基于粒子群的ieee30节点优化、配电网有功-无功优化
- SPI 读取不同长度 寄存器_MCGS触摸屏如何实现批量读取modbus数据的方法?
- ios降级后无法用itunes恢复新版本的备份
- 用ps制作android日历步骤,PS设计制作日历
- 奇摩,你来大陆干什么?
- Qt源码分析--QPaintEngine
- Echarts绘制Tree树图的涟漪效果effectScatter
- 5年市值蒸发2000多亿 绿地控股二次混改能否迎来春天?
- html网络语言什么意思,网络语言开车什么意思 网络用语开车是什么意思
- 区块链技术:未来将颠覆的9大行业