• 大话设计模式—中介者模式


    中介者模式(Mediator Pattern)是用来减少多个对象和类之间的通信复杂性。

    这种模式提供了一个中介类,该类通常处理不同类之间的通信,并支持松耦合。使代码易于维护。

    中介者模式属于行为型模式。

    引言:

    虽然一个系统切割成很多对象通常能够添加其可复用性。可是对象间相互连接次数的添加又会减少其可复用性;大量的连接使得一个对象不可能在没有其它对象的支持下工作。系统表现为一个不可切割的总体,所以,对系统的行为进行不论什么较大的修改就十分困难了。

    要解决这种问题。我们能够使用 迪米特原则 ,假设两个类不必彼此直接通信,那么这两个类就不应当发生直接的相互作用。假设须要相互调用,能够通过第三方来转发。

    通过中介者对象,能够将系统的网状结构变成以中介者为中心的星型结构,每一个详细对象不再通过直接的联系与还有一个详细对象进行通信,而是通过中介者对象。中介者对象的设计使得系统的结构不会由于新对象的引入而造成大量的修改工作。

    例如以下图联合国与各个国家的关系就是一个非常贴切的样例:

    联合国与各国联系关系图

    大话设计模式中程杰老师给出的定义是:

    中介者模式。用一个中介对象来封装一系列的对象交互。中介者使各对象不须要显示的相互引用,从而使其耦合松散,并且能够独立的改变他们之间的交互。

    中介者模式结构图

    代码实例:

    抽象中介者

    public abstract class Mediator{
    
        /**
         * 定义一个抽象的发送消息方法
         *  功能:得到同事对象和发送消息
         */
        public abstract void Send(String message,Colleague colleague);
    
    }

    抽象同事类

    public abstract classColleague{
    
        protected Mediator mediator;
    
        //构造方法,得到中介者对象
        public Colleague(){
            this.mediator = mediator;
        }
    }

    中介者实现类

    public class ConcreteMediator implements Mediator{
    
        private ConcreteMediatorA colleagueA;
        private ConcreteMediaorB colleagueB;
    
        //setter and getter
    
        //重写发送消息的方法,依据详细发送消息的对象去通知接收消息的对象
        public void send(String message,Colleague colleague){
            if(colleague == colleagueA){
                colleagueB.notify(message);
            }
            colleagueA.notify(message);
        }
    }

    同事对象实现类A

    public class ConcreteColleagueA implements Colleague{
    
        public ConcreteColleagueA(Mediator mediator){
            this.mediator = mediator;
        }
    
        public void send(String message){
            //消息是通过中介者发送出去的
            mediator.send(message,this.concreteColleagueA);
        }
    
        public void notify(String message){
            Systen.out.println("A同事收到消息:" + message);
        }
    }

    同事对象实现类B

    public class ConcreteColleagueB implements Colleague{
    
        public ConcreteColleagueB(Mediator mediator){
            this.mediator = mediator;
        }
    
        public void send(String message){
            //消息是通过中介者发送出去的
            mediator.send(message,this.concreteColleagueB);
        }
    
        public void notify(String message){
            Systen.out.println("B同事收到消息:" + message);
        }
    }

    測试类

    public static void main(String[] args){
    
        ConcreteMediator mediator = new ConcreteMediator();
    
        //让两个详细同事类对象认识中介者对象
        ConcreteColleagueA colleagueA = new ConcreteColleagueA(mediator);
        ConcreteColleagueB colleagueB = new ConcreteColleagueB(mediator);
    
        mediator.colleagueA = colleagueA;
        mediator.colleagueB = colleagueB;
    
        colleagueA.send("hi,nice to meet you!");
        colleagueB.send("nice to meet you too!");
    }

    执行结果:

    B同事收到消息:hi,nice to meet you!
    A同事收到消息:nice to meet you too!

    长处:

    1、减少了类的复杂度,将一对多转化成了一对一。
    2、各个类之间的解耦。


    3、符合迪米特原则。

    缺点:中介者会庞大。变得复杂难以维护。

    使用场景

    1、系统中对象之间存在比較复杂的引用关系,导致它们之间的依赖关系结构混乱并且难以复用该对象。
    2、想通过一个中间类来封装多个类中的行为。而又不想生成太多的子类。

    注意事项:不应当在职责混乱的时候使用。

    中介者模式的长处来自于集中控制,其缺点也是(中介者对象必须知道全部的同事对象),使用时要考虑清楚。

  • 相关阅读:
    返回顶部按钮效果实现
    WebAPI Angularjs 上传文件
    C# 单元测试
    C# 如何获取Url的host以及是否是http
    Dapper批量操作实体
    易优CMS:type的基础用法
    易优CMS:arcview基础用法
    易优CMS:channel的基础用法
    易优CMS:arclist 文档列表
    c语言必背代码
  • 原文地址:https://www.cnblogs.com/zhchoutai/p/7183758.html
Copyright © 2020-2023  润新知