中介者模式

应用场景


当类的关系图呈现网状结构的时候,这时可以考虑使用使用中介者模式,它能够将这种网状结构的类关系转化为星型结构,降低了类与类之间的耦合度。

类图描述


Mediator:抽象中介者,定义同一接口,用于各同事角色之间的通讯

ConcreteMediator:具体中介角色,协调各同事角色实现协作行为

Colleague:每个同事角色都知道中介者角色,并且与其他同时角色进行通信的时候一定要通过中介者角色协作。每个同事类有两种行为:自发行为(自行完成,不依赖他人),依赖方法(需要借助中介者才能完成)

示例代码


通用抽象中介者

这里将具体的同事类而不将抽象同事类进行注入,是因为每个同事类干的活是不一样的

public abstract class Mediator{
    //定义同事类
    protected ConcreteColleague1 c1;
    protected ConcreteColleague2 c2;

    //通过getter/setter将同事类注入
    public ConcreteColleague1 getC1() {
        return c1;
    }
    public void setC1(ConcreteColleague1 _c1) {
        this.c1 = _c1;
    }
    public ConcreteColleague2 getC2() {
        return c2;
    }
    public void setC2(ConcreteColleague2 _c2) {
        this.c2 = _c2;
    }
    
    public abstract void doSomething1();
    public abstract void doSomething2();
}

具体中介者

在具体中介者中根据业务来调用不同的同事类进行处理

public class ConcreteMediator extends Mediator{

    @Override
    public void doSomething1() {
        //调用同事类的方法
        super.c1.selfMethod1();
        super.c2.selfMethod2();
    }

    @Override
    public void doSomething2() {
        super.c2.selfMethod2();
    }
    
}

 抽象同事类

抽象同事类中需要持有中介的引用,是因为自己干不了的事可以提交给中介来处理

public abstract class Colleague{
    protected Mediator mediator;
    public Colleague(Mediator _mediator){
        this.mediator = _mediator;
    }
}

具体同事类

public class ConcreteColleague1 extends Colleague{
    //通过构造函数传递中介者
    public ConcreteColleague1(Mediator _mediator){
        super(_mediator);
    }
    
    //自由方法self-method
    public void selfMethod1(){
        //处理自己的业务逻辑
    }
    
    //依赖方法dep-method
    public void depMethod1(){
        //处理自己的业务
      //自己不能处理的委托中介处理
      super.mediator.doSomething1();
} }

 总结


优点:减少类之间的相互依赖,从一对多变为一对一

缺点:关系越复杂会导致的中介者膨胀越厉害,比如doSomething的实现就更加苦难。所以使用中介者模式需要量力而行。

原文地址:https://www.cnblogs.com/xidongyu/p/5812708.html