概念:

  Mediator模式也叫中介者模式,是由GoF提出的23种软件设计模式的一种。Mediator模式是行为模式之一,在Mediator模式中,类之间的交互行为被统一放在Mediator的对象中,对象通过Mediator对象同其他对象交互,Mediator对象起着控制器的作用。

  中介者模式其实就好比租房中介和相亲网站一样,房东将信息发布到租房中介,而租客可以中介挑选自己理想的房子,或者单身男女各自将自己的信息发布到相亲网站,同时也可以挑选符合自己条件的另一半。

  拿相亲网站举个例子,首先不用中介者模式

  相亲,肯定是人相亲,所以新建一个Person类,并提供一个getCompanion(Person person)方法

 public abstract class Person {
private String name;
private int condition; public Person(String name, int condition){
this.name = name;
this.condition = condition;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getCondition() {
return condition;
} public void setCondition(int condition) {
this.condition = condition;
} //得到是否符合信息
public abstract void getCompanion(Person person);
}

  人肯定是分为男人和女人,所以在新建Man与Woman类

 public class Man extends Person {

     public Man(String name, int condition) {
super(name, condition);
} @Override
public void getCompanion(Person person) {
if(person instanceof Man){
System.out.println("我不是gay");
}else{
if(person.getCondition() == this.getCondition()){
System.out.println(this.getName()+"先生与"+person.getName()+"女士"+"非常般配");
}else{
System.out.println(this.getName()+"先生与"+person.getName()+"女士"+"不合适");
}
}
}
}
 public class Woman extends Person{

     public Woman(String name, int condition) {
super(name, condition);
} @Override
public void getCompanion(Person person) {
if(person instanceof Woman){
System.out.println("我不是gay");
}else{
if(person.getCondition() == this.getCondition()){
System.out.println(this.getName()+"女士与"+person.getName()+"先生"+"非常般配");
}else{
System.out.println(this.getName()+"女士与"+person.getName()+"先生"+"不合适");
}
}
}
}

  在写一个客户端

 public class MainCLass {
public static void main(String[] args) {
Person xiaoming = new Man("小明",1);
Person xiaoqiang = new Man("小强",2); Person xiaohong = new Woman("小红",1); xiaoming.getCompanion(xiaohong); xiaoqiang.getCompanion(xiaohong); xiaoming.getCompanion(xiaoqiang);
}
}

  运行结果:

  可以看到,这种形式判断对方是否合适都交给了男女双方自己来解决,自己去寻找是否符合条件的,像大海捞针一样,不管是男,女人,甚至不是人都要挨个去比较。

  同时这样Man和Woman之间存在了一个交互行为,大大提高了代码的耦合性,如果这两个类中都有自己特定的方法需要对方调用时,只要一方修改,另一方就需要跟着修改。两个类紧紧联系到了一起,这样的设计是很不好的。

  下面,正式进入中介者模式

  中介者模式结构图

  

  

  中介者模式的角色和职责

  1、Mediator:中介者类的抽象父类 
    抽象中介者角色定义统一的接口,用于各角色(男和女)之间的通信。

  2、ConcreteMediator:具体中介者角色 
    具体中介者角色,通过协调各角色(男和女)实现协作行为,因此它必须依赖于各个角色。

  3、Colleague:关联类的抽象父类
    每一个角色都知道中介者角色,而且与其它的角色通信的时候,一定要通过中介者角色来协作。 
    每个类(Person)的行为分为二种(男和女):一种是男女本身的行为,这种行为叫做自发行为(Self-Method);第二种是必须依赖中介者才能完成的行为,叫做依赖行为(Dep-Method)。

  4、concreteColleague:具体的关联类(Man和Woman)。

  下面,用代码实现中介者模式

  首先新建一个Mediator

 public abstract class Mediator {
private Man man;
private Woman woman; public Man getMan() {
return man;
}
public void setMan(Man man) {
this.man = man;
}
public Woman getWoman() {
return woman;
}
public void setWoman(Woman woman) {
this.woman = woman;
} //比较条件的方法
public abstract void getCompanion(Person person);
}

  在新建一个ConcreteMediator:具体中介者角色

 public class BlindDateMediator extends Mediator{
@Override
public void getCompanion(Person person) {
if(person instanceof Man) {
this.setMan((Man)person);
} else {
this.setWoman((Woman)person);
} //如果是同性
if(this.getMan() == null || this.getWoman() == null) {
System.out.println("我不是gay");
}else {
//条件合适
if(this.getMan().getCondition() == this.getWoman().getCondition()) {
System.out.println(this.getMan().getName() + "先生与" + this.getWoman().getName() + "女士很般配");
//条件不合适
}else {
System.out.println(this.getMan().getName() + "先生" + this.getWoman().getName() + "女士不合适");
}
} //比较之后,将条件置空,不然会影响下一次比较
this.setMan(null);
this.setWoman(null);
}
}

  接下来,新建Person,Man与Woman

 public abstract class Person {
private String name;
private int condition;
private Mediator mediator; public Person(String name, int condition, Mediator mediator){
this.name = name;
this.condition = condition;
this.mediator = mediator;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public int getCondition() {
return condition;
} public void setCondition(int condition) {
this.condition = condition;
} public Mediator getMediator() {
return mediator;
} public void setMediator(Mediator mediator) {
this.mediator = mediator;
} //得到是否符合信息
public abstract void getCompanion(Person person);
}
 public class Man extends Person {

     public Man(String name, int condition, Mediator mediator) {
super(name, condition, mediator);
} @Override
public void getCompanion(Person person) {
this.getMediator().setMan(this);
this.getMediator().getCompanion(person);
}
}
 public class Woman extends Person{

     public Woman(String name, int condition, Mediator mediator) {
super(name, condition, mediator);
} @Override
public void getCompanion(Person person) {
this.getMediator().setWoman(this);
this.getMediator().getCompanion(person);
}
}

  最后是客户端

 public class MainCLass {
public static void main(String[] args) {
Mediator mediator = new BlindDateMediator();
Person xiaoming = new Man("小明",1,mediator);
Person lisi = new Man("李四",2,mediator);
Person xiaohong = new Woman("小红",1,mediator); xiaoming.getCompanion(xiaohong); lisi.getCompanion(xiaohong); xiaoming.getCompanion(lisi);
}
}

  运行结果如下:

  中介者模式的优缺点

  优点:

  1,将系统按功能分割成更小的对象,符合类的最小设计原则

  2,对关联对象的集中控制

  3,减小类的耦合程度,明确类之间的相互关系:当类之间的关系过于复杂时,其中任何一个类的修改都会影响到其他类,不符合类的设计的开闭原则 ,而Mediator模式将原来相互依存的多对多的类之间的关系简化为Mediator控制类与其他关联类的一对多的关系,当其中一个类修改时,可以对其他关联

类不产生影响(即使有修改,也集中在Mediator控制类)。

  4,有利于提高类的重用性

  缺点:

  中介者会膨胀得很大,而且逻辑复杂,原本N个对象直接的相互依赖关系转换为中介者和同事类的依赖关系,同事类越多,中介者的逻辑就越复杂。

java设计模式-----17、中介者模式的更多相关文章

  1. 折腾Java设计模式之中介者模式

    博文原址:折腾Java设计模式之中介者模式 中介者模式 中介者模式(Mediator Pattern)是用来降低多个对象和类之间的通信复杂性.这种模式提供了一个中介类,该类通常处理不同类之间的通信,并 ...

  2. 从中国加入WTO来看Java设计模式:中介者模式

    目录 应用场景 中介者模式 定义 意图 主要解决问题 何时使用 优缺点 世界贸易组织WTO 应用场景 系统中对象之间存在比较复杂的引用关系,导致它们之间的依赖关系结构混乱而且难以复用该对象 想通过一个 ...

  3. [设计模式] 17 中介者模式 Mediator Pattern

    在GOF的<设计模式:可复用面向对象软件的基础>一书中对中介者模式是这样说的:用一个中介对象来封装一系列的对象交互.中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变 ...

  4. Java 设计模式之中介者模式

    本文继续23种设计模式系列之中介者模式.   定义 用一个中介者对象封装一系列的对象交互,中介者使各对象不需要显示地相互作用,从而使耦合松散,而且可以独立地改变它们之间的交互.   角色 抽象中介者: ...

  5. java设计模式之中介者模式

    中介者模式 用一个中介对象来封装一系列的对象交互.中介者使各个对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互. 中介者模式UML图 中介者模式代码 package com ...

  6. Java 设计模式 之 中介者模式(Mediator)

    中介者的功能非常简单,就是封装对象之间的交互. 如果一个对象的操作会引起其他相关对象的变化,或者是某个操作需要引起其他对象的后续或连带操作,而这个对象又不希望自己来处理这些关系,那么久可以找中介者,把 ...

  7. 18.java设计模式之中介者模式

    基本需求 智能家庭包括各种设备,闹钟.咖啡机.电视机.窗帘等 要看电视时,各个设备可以协同工作,自动完成看电视的准备工作,比如流程为:闹铃响起->咖啡机开始做咖啡->窗帘自动落下-> ...

  8. Java设计模式之《代理模式》及应用场景

    原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/6525527.html 代理模式算是我接触较早的模式,代理就是中介,中间人.法律上也有代理, ...

  9. Java设计模式之工厂方法模式(转) 实现是抽象工厂?

    Java设计模式之工厂方法模式 责任编辑:覃里作者:Java研究组织   2009-02-25   来源:IT168网站   文本Tag: 设计模式 Java [IT168 技术文章]         ...

  10. Java设计模式 - - 单例模式 装饰者模式

    Java设计模式 单例模式 装饰者模式 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 静态代理模式:https://www.cnblogs.com/StanleyBlogs/p/1 ...

随机推荐

  1. 【文文殿下】ExBSGS

    无需逆元版本: #include<cstdio> #include<cassert> #include<cmath> #include<map> typ ...

  2. Django 定时任务实现(django-crontab+command)

    一.编写自定义django-admin命令 注:利用django-admin自定义命令我们可以ORM框架对model进行操作,如:定时更新数据库,检测数据库状态..... Django为项目中每一个应 ...

  3. $_REQUEST预定义变量

    1,$_REQUEST接收$_GET,$_POST,$_COOKIE数据,因此这三种方式都可以攻击$_REQUEST方式,这种方式不安全,不建议使用$_REQUEST. 2,如果不知道get或post ...

  4. Alamofire源码导读二:发起请求及内部加锁的逻辑

    以创建一个 DataRequest 为例子  发起请求 创建 SessionManager 顺带也创建了一个 SessionDelegate 持有一个urlSession,持有一个串行的 Dispa ...

  5. D11——C语言基础学PYTHON

    C语言基础学习PYTHON——基础学习D11 20180908内容纲要: 1.RabbitMQ消息队列 (1)RabbitMQ安装 (2)Rabbits示例 模式一:fanout 模式二:direct ...

  6. 用Lingo求解线性规划问题

    第一步:输入目标条件和约束条件.每行以分号隔开.然后点击工具栏上的Solve按钮,或Lingo菜单下的Solve子菜单. 第二步:检查report中的结果. 默认情况下,Lingo不进行灵敏度分析. ...

  7. Python字典按值排序、包含字典的列表按字典值排序的方法

    operator.itemgetter函数 operator模块提供的itemgetter函数用于获取对象的哪些维的数据,参数为一些序号(即需要获取的数据在对象中的序号),要注意,operator.i ...

  8. Java 并发编程——volatile与synchronized

    一.Java并发基础 多线程的优点 资源利用率更好 程序设计在某些情况下更简单 程序响应更快 这一点可能对于做客户端开发的更加清楚,一般的UI操作都需要开启一个子线程去完成某个任务,否者会容易导致客户 ...

  9. EJB3 jpa 数据库表的映射关系

    1)多对一映射关系(单向) 使用外键关联,在外键的选取上以多的一方为主,即外键要在多的一方体现出来 @Entity public class Company implements Serializab ...

  10. Git-基本操作(图文)

    场景一: 已经用git add 命令把文件加入到暂存区了,这个时候想退回怎么办? 添加文件到暂存区 :git add . 将单个文件撤回到工作区:git rm --cached [文件路径] 将目录撤 ...