这篇博客我想简单介绍一下中介者模式
中介者模式(Mediator Pattern)是用来降低多个对象和类之间的通信复杂性。这种模式提供了一个中介类,该类通常处理不同类之间的通信,并支持松耦合,使代码易于维护。中介者模式属于行为型模式。也就是避免了多个类之间直接通信从而使得代码耦合度较大,采用一个中介类使原本的网状结构变成星型结构。
意图:用一个中介对象来封装一系列的对象交互,中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。
这个模式理解起来非常容易,但是在代码的实现方面有许多需要注意的地方。
首先介绍一下代码的结构。需要一个中介类接口,一个需要调用其他类职能的接口,所有的类都需要实现这个接口(Department)。以及相应的实现类。
首先来看一下中介类部分的实现。
public interface Mediator {
void register(String dname,Department d);
void command(String dname);
}
首先是register方法,这个方法是让每一个同事类,也就是Department接口的实现类都注册和维护到Mediator对应的实现类的一个HashMap中。
command方法则是根据提出的申请去HashMap中找到相应的Department接口实现类进行问题的解决。
单纯的看中介部分十分难懂,还需要参考Department部分之间的通信方式来理解。
首先是同事类的接口
//同事类的接口
public interface Department {
void selfAction(); //做本部门的事情
void outAction(); //向总经理发出申请
}
我们来声明两个类,一个表示市场,一个表示财务
首先是市场类
public class Market implements Department {
private Mediator m; //持有中介者(总经理)的引用
public Market(Mediator m) {
super();
this.m = m;
m.register("market", this);
}
@Override
public void outAction() {
System.out.println("汇报工作!项目承接的进度,需要资金支持!");
m.command("finacial");
}
@Override
public void selfAction() {
System.out.println("跑去接项目!");
}
}
我们来仔细分析一下这个类。首先它持有一个中介者的引用,这个中介者也就是经理来执行相应的outAction也就是通信任务。
在构造方法中,需要将这个类注册到经理类(President)中的HashMap中。首先来看outAction()方法,也就是通信使用的方法。它调用了Mediator 接口中的command()方法。我们来看一下command()方法的具体实现。
@Override
public void command(String dname) {
map.get(dname).selfAction();
}
可以看到是通过去map中查找指定的通信目的对象来调用其中的selfAction()也就是目的对象的职能方法。
这个Finacial代码如下,具体的我就不解释了。
public class Finacial implements Department {
private Mediator m; //持有中介者(总经理)的引用
public Finacial(Mediator m) {
super();
this.m = m;
m.register("finacial", this);
}
@Override
public void outAction() {
System.out.println("汇报工作!没钱了,钱太多了!怎么花?");
}
@Override
public void selfAction() {
System.out.println("数钱!");
}
}
客户端测试代码如下
public class Client {
public static void main(String[] args) {
Mediator m = new President();
Market market = new Market(m);
Development devp = new Development(m);
Finacial f = new Finacial(m);
market.selfAction();
market.outAction();
}
}