中介者模式的本质
解耦多个同事对象之间的交互关系,每个对象都持有中介者对象的引用,只跟中介者对象打交道。而通过中介者对象来统计管理这些交互关系。 即将原来的同事对象之间的多对多关系,转化为同事对象和中介者对象之间的一对多关系。
常见的场景:
- MVC模式中的C,即是中介者对象,来管理M和V
- GUI开发中,窗口对象作为中介者对象,所有的内部的组件只和窗口对象交互
/**
* 中介者对象
*/
public interface Midium {
//注册(同事对象主动与中介者对象交互)
void register(String key,Colleague colleague);
//执行(中介者对象管理同事对象)
void command(String key);
}
复制代码
/**
* 同事者对象
*/
public interface Colleague {
void selfAction(); //执行自己的操作
void outAction(); //执行外部的操作
}
复制代码
中介者对象用于调用其他对象,并接受其他对象的引用。 同事对象用于持有中介者对象的引用,通过中介者对象来与其他同事对象交互。
/**
* 中介者对象的实现类
*
* @author Harvey
* @create 2018-04-06 下午10:54
**/
public class MidiumImpl implements Midium{
Map<String,Colleague> map = new HashMap<>();
@Override
public void register(String key, Colleague colleague) {
map.put(key,colleague);
}
@Override
public void command(String key) {
map.get(key).selfAction();
}
}
复制代码
/**
* 同事者对象1
*
* @author Harvey
* @create 2018-04-06 下午10:53
**/
public class Colleague1 implements Colleague{
private Midium midium;
public Colleague1(Midium midium) {
this.midium = midium;
midium.register("midium1",this);
}
@Override
public void selfAction() {
System.out.println("01自身的业务执行");
}
@Override
public void outAction() {
System.out.println("申请调用其他的同事对象");
midium.command("midium2");
}
}
/**
* 同事者对象2
*
* @author Harvey
* @create 2018-04-06 下午10:53
**/
public class Colleague2 implements Colleague{
private Midium midium;
public Colleague2(Midium midium) {
this.midium = midium;
midium.register("midium2",this);
}
@Override
public void selfAction() {
System.out.println("02自身的业务执行");
}
@Override
public void outAction() {
System.out.println("02被中介者对象调用");
}
}
复制代码
测试结果
public static void main(String[] args) {
Midium midium = new MidiumImpl();
Colleague1 colleague1 = new Colleague1(midium);
Colleague2 colleague2 = new Colleague2(midium);
colleague1.selfAction();
colleague1.outAction();
}
结果:
01自身的业务执行
申请调用其他的同事对象
02自身的业务执行
复制代码