设计模式之中介者模式:让互相调用的模块之间解耦合

场景

场景1:

(1)三个模块

(2)模块1调用模块2和模块3;模块2要调用模块1和模块3;模块3要调用模块1和模块2

场景2:

(1)电商系统:订单、库存、调度中心之间交互,使用中介者模式做成完全解耦。

内容

  1. 中介者模式(Mediator Pattern)是用来降低多个对象和类之间的通信复杂性。这种模式提供了一个中介类,该类通常处理不同类之间的通信,并支持松耦合,使代码易于维护。中介者模式属于行为型模式。
  2. 用一个中介对象来封装一系列的对象交互,中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。

1. 不使用设计模式

1.1 类图
1.2 代码
  1. 每个模块提供一个供别人调用的方法:

    复制代码
    excute(String invoker)
  2. 真正代码耦合调用逻辑在:excute里面

    public class NonPattern2 {
    public static void main(String[] args) {
    Module1 module1 = new Module1();
    Module2 module2 = new Module2();
    Module3 module3 = new Module3();

    复制代码
         module1.excute();
         module2.excute();
         module3.excute();
    
         /**
          * 输出:
          * 模块1在调用模块2功能
          * 模块1在调用模块3功能
          * 模块2在调用模块1功能
          * 模块2在调用模块3功能
          * 模块3在调用模块1功能
          * 模块3在调用模块2功能
          */
     }
    
    public static class Module1{
         public void excute(){
            //模块1调用模块2 和 模块3
             Module2 module2 = new Module2();
             Module3 module3 = new Module3();
    
             module2.excute("模块1");
             module3.excute("模块1");
         }
         public void excute(String invoker){//执行者
           System.out.println(invoker+"在调用模块1功能");
         }
    }
    
     public static class Module2{
         public void excute(){
             //模块2 调用模块1 和 模块3
             Module1 module1 = new Module1();
             Module3 module3 = new Module3();
    
             module1.excute("模块2");
             module3.excute("模块2");
         }
         public void excute(String invoker){//执行者
             System.out.println(invoker+"在调用模块2功能");
         }
     }
    
     public static class Module3{
         public void excute(){
             //模块3 调用模块1 和 模块2
             Module1 module1 = new Module1();
             Module2 module2 = new Module2();
    
             module1.excute("模块3");
             module2.excute("模块3");
         }
         public void excute(String invoker){//执行者
             System.out.println(invoker+"在调用模块3功能");
         }
     }

    }

2. 中介者模式

2.1 类图
  1. 模块和中介者互相依赖。
  2. 为了实现模块之间调用解耦,把模块的调用书写在Mediator,然后调用行为传参给各个模块,然后执行调用,相当于把调用当成一个组件分离出去,需要调用的时候,直接传递此组件。
  3. 每个模块提供一个供其他模块调用的方法
  4. 因为最后触发调用的是各个模块主动触发,所以我们需要在各个模块书写:excute方法
2.2 代码
复制代码
public class MediatorPattern2 {
    public static void main(String[] args) {
        //1.创建中介者
        Mediator mediator = new Mediator();

        //2.创建个模块并且给创建的中介者赋值
        Module1 module1 = new Module1(mediator);
        Module2 module2 = new Module2(mediator);
        Module3 module3 = new Module3(mediator);

        //3.输出调用
        module1.excute();
        module2.excute();
        module3.excute();

        /**
         * 输出:
         * 模块1通知中介者 : 在调用模块2功能
         * 模块1通知中介者 : 在调用模块2功能
         * 模块2通知中介者 : 在调用模块1功能
         * 模块2通知中介者 : 在调用模块2功能
         * 模块3通知中介者 : 在调用模块1功能
         * 模块3通知中介者 : 在调用模块2功能
         */
    }

    //=======================中介者========================
    public static class Mediator{
        private Module1 module1;
        private Module2 module2;
        private Module3 module3;

        public void module1Invoke(){
            module2.excute("模块1通知中介者 ");
            module3.excute("模块1通知中介者 ");
        }
        public void module2Invoke(){
            module1.excute("模块2通知中介者 ");
            module3.excute("模块2通知中介者 ");
        }

        public void module3Invoke(){
            module1.excute("模块3通知中介者 ");
            module3.excute("模块3通知中介者 ");
        }

        public Module1 getModule1() {
            return module1;
        }

        public void setModule1(Module1 module1) {
            this.module1 = module1;
        }

        public Module2 getModule2() {
            return module2;
        }

        public void setModule2(Module2 module2) {
            this.module2 = module2;
        }

        public Module3 getModule3() {
            return module3;
        }

        public void setModule3(Module3 module3) {
            this.module3 = module3;
        }
    }


    public static class Module1{
        private Mediator mediator;

        public Module1(Mediator mediator){
            this.mediator = mediator;
            this.mediator.setModule1(this);
        }

        public void excute(){
            mediator.module1Invoke();
        }
        public void excute(String invoker){
          System.out.println(invoker+": 在调用模块1功能");
       }
    }

    public static class Module2{
        private Mediator mediator;

        public Module2(Mediator mediator){
            this.mediator = mediator;
            this.mediator.setModule2(this);
        }

        public void excute(){
            mediator.module2Invoke();
        }
        public void excute(String invoker){
            System.out.println(invoker+": 在调用模块2功能");
        }
    }

    public static class Module3{
        private Mediator mediator;

        public Module3(Mediator mediator){
            this.mediator = mediator;
            this.mediator.setModule3(this);
        }

        public void excute(){
            mediator.module3Invoke();
        }
        public void excute(String invoker){
            System.out.println(invoker+": 在调用模块2功能");
        }
    }
}

3.总结

3.1 不使用设计模式对比
  1. 模块之间有非常复杂的互相之间的跟蜘蛛网一样的调用;每个模块都要去care很多其他的模块,互相之间耦合很严重
  2. 后面在修改代码的时候,代码不好改,模块2一旦修改了自己的代码,可能会影响模块1和模块3
3.2 使用原型模式

优点:

  1. module1,只要知道一个中介者就可以了,具体跟其他模块的交互都封装在中介者里面了。
  2. module2,只要知道一个中介者就可以了,具体跟其他模块的交互都封装在中介者里面了。
  3. module3,只要知道一个中介者就可以了,具体跟其他模块的交互都封装在中介者里面了。
  4. module1、2、3之间不再有任何的耦合,不再有复杂的交互关系,互相之间修改不会对对方产生什么影响。
相关推荐
absunique3 小时前
算法设计模式看编程思维的抽象能力的技术6
算法·设计模式
蜜獾云3 小时前
设计模式之构造器模式:封装复杂对象的构造逻辑
java·开发语言·设计模式
AI2512246 小时前
AI视频生成器技术评测:运动质量与稳定性分析
人工智能·microsoft·音视频
Anurmy6 小时前
设计模式之桥接模式
设计模式·桥接模式
OxyTheCrack10 小时前
【C++】简述Observer观察者设计模式附样例(C++实现)
开发语言·c++·笔记·设计模式
愿天堂没有C++10 小时前
Pimpl 设计模式(指针指向实现)
开发语言·c++·设计模式
娇娇yyyyyy11 小时前
QT编程(5):几种常用的对话框
windows·qt·microsoft
胖虎111 小时前
iOS中的设计模式(十二)- 迭代器模式(Iterator Pattern)在 iOS 开发中的实践
设计模式·迭代器模式
sanshizhang11 小时前
设计模式-责任链模式
java·设计模式·责任链模式