zoukankan      html  css  js  c++  java
  • 中介者模式

    定义:定义一个中介对象来封装一系列对象之间的交互,使原有对象之间的耦合松散,且可以独立的改变它们之间的交互,中介者模式又叫调停模式,它是迪米特法则的典型应用

    优点:

    1,降低对象之间的耦合性,使得对象易于独立的被复用

    2,将对象间的一对多关联转变为一对一关联,提高系统的灵活性,使得系统易于维护和扩展

    缺点:

    当同事类太多时,中介者的职责将很大,它会变得庞大而复杂,以至于系统难以维护

    模式的结构

    1,抽象中介者角色:他是中介者的接口,提供了同事对象的注册和转发同事对象信息的抽象方法

    2,具体中介者角色:实现中介者接口,定义一个List来管理同事对象,协调各个同事角色之间的交互关系,因此它依赖于同事角色

    3,抽象同事类角色:定义同事类接口,保存中介者对象,提供同事对象交互的抽象方法,实现所有相互影响的同事类的公共功能

    4,具体同事类角色:是抽象同事类的实现者,当需要与其他同事对象交互时,由中介者对象负责后续的交互

    结构图

    代码:

    package mediator;
    import java.util.*;
    public class MediatorPattern
    {
        public static void main(String[] args)
        {
            Mediator md=new ConcreteMediator();
            Colleague c1,c2;
            c1=new ConcreteColleague1();
            c2=new ConcreteColleague2();
            md.register(c1);
            md.register(c2);
            c1.send();
            System.out.println("-------------");
            c2.send();
        }
    }
    //抽象中介者
    abstract class Mediator
    {
        public abstract void register(Colleague colleague);
        public abstract void relay(Colleague cl); //转发
    }
    //具体中介者
    class ConcreteMediator extends Mediator
    {
        private List<Colleague> colleagues=new ArrayList<Colleague>();
        public void register(Colleague colleague)
        {
            if(!colleagues.contains(colleague))
            {
                colleagues.add(colleague);
                colleague.setMedium(this);
            }
        }
        public void relay(Colleague cl)
        {
            for(Colleague ob:colleagues)
            {
                if(!ob.equals(cl))
                {
                    ((Colleague)ob).receive();
                }   
            }
        }
    }
    //抽象同事类
    abstract class Colleague
    {
        protected Mediator mediator;
        public void setMedium(Mediator mediator)
        {
            this.mediator=mediator;
        }   
        public abstract void receive();   
        public abstract void send();
    }
    //具体同事类
    class ConcreteColleague1 extends Colleague
    {
        public void receive()
        {
            System.out.println("具体同事类1收到请求。");
        }   
        public void send()
        {
            System.out.println("具体同事类1发出请求。");
            mediator.relay(this); //请中介者转发
        }
    }
    //具体同事类
    class ConcreteColleague2 extends Colleague
    {
        public void receive()
        {
            System.out.println("具体同事类2收到请求。");
        }   
        public void send()
        {
            System.out.println("具体同事类2发出请求。");
            mediator.relay(this); //请中介者转发
        }
    }

     应用场景

    当对象之间存在复杂的网状结构关系而导致依赖关系混乱且难以复用时。

    当想创建一个运行于多个类之间的对象,又不想生成新的子类时。  

  • 相关阅读:
    YARN源码学习(七)-----Task级别GC相关指标的自定义counter添加
    YARN源码学习(七)-----Task级别GC相关指标的自定义counter添加
    YARN源码分析(八)-----Reduce Shuffle过程分析
    YARN源码分析(八)-----Reduce Shuffle过程分析
    【每天一道算法题】整数循环节之和——数字黑洞6174
    getline函数
    设计模式之建造者模式Builder(创建型)
    字符串算法总结
    C++设计模式之单例模式
    Linux下C的线程同步机制
  • 原文地址:https://www.cnblogs.com/cwb123/p/13911949.html
Copyright © 2011-2022 走看看