设计模式之调停者 Mediator

简介: 设计模式之调停者 Mediator

核心思想:通过引入一个中介对象来降低对象之间的直接交互。在该模式中,调停者对象充当了所有相关对象之间的协调者,其主要作用是接收并处理这些对象发出的请求。通过使用调停者模式,可以减少对象之间的依赖性,从而提高系统的可维护性和可扩展性

场景:假设在一个游戏中,现在有A、B、C三名玩家,有一名玩家释放技能,其他两名玩家就会减少HP2点,那么这个时候如果按照传统的设计,A、B、C之间就需要相互耦合,这显然就违背了迪米特原则,因此就有了调停者模式。将释放技能这个操作交给调停者来做,调停者持有A、B、C三个对象

调停者模式的必备要素:

  • 抽象调停者: 定义了同事类与调停者交互的接口,其中主要方法是一个事件方法。
  • 具体调停者: 实现了抽象调停者定义的事件方法,同时具体调停者知道所有具体的同事类,并且负责协调各同事类之间的交互。
  • 抽象同事类:定义了调停者和同事类的交互接口,同事对象只知道调停者,而不知道其他的同事对象。
  • 具体同事类:具体同事类都是继承自抽象同事类。实现自己的业务,然后当要与其他同事类进行通信的时候,就与持有的调停者进行通信,调停者负责与其他同事类进行交互。

下面我们看一下具体的代码实现:

首先,创建一个抽象的同事类,需要持有调停者类,并提供方法来操作对象的属性

public abstract class AbstractHero {
    protected AbstractMediator mediator;
    protected int HP;
    public AbstractHero(AbstractMediator mediator) {
        HP = 0;
        this.mediator = mediator;
    }
    abstract void printHP();
    public void addHP(int i) {
        this.HP += i;
    }
    public void subtractHP(int i) {
        this.HP -= i;
    }
}

然后我们定义抽象的调停者类,提供操作方法即可

public abstract class AbstractMediator {
    abstract void useSkill(AbstractHero hero);
}

具体的同事类:

public class A extends AbstractHero{
    public A(AbstractMediator mediator) {
        super(mediator);
    }
    @Override
    void printHP() {
        System.out.println(this.HP);
    }
}
public class B extends AbstractHero{
    public B(AbstractMediator mediator) {
        super(mediator);
    }
    @Override
    void printHP() {
        System.out.println(this.HP);
    }
}
public class C extends AbstractHero{
    public C(AbstractMediator mediator) {
        super(mediator);
    }
    @Override
    void printHP() {
        System.out.println(this.HP);
    }
}

最后定义具体的调停者类,需要持有所有的同事类的对象

public class GameMediator extends AbstractMediator{
    private static final GameMediator GAME_MEDIATOR = new GameMediator();
    private GameMediator(){}
    private A a;
    private B b;
    private C c;
    public static GameMediator getGameMediator(){
        return GAME_MEDIATOR;
    }
    @Override
    void useSkill(AbstractHero hero) {
        if (hero instanceof A){
            System.out.println("A发动技能:A回复两点HP,B、C扣除两点HP");
            a.addHP(2);
            b.subtractHP(2);
            c.subtractHP(2);
        }else if (hero instanceof B){
            System.out.println("B发动技能:B回复两点HP,A、C扣除两点HP");
            b.addHP(2);
            a.subtractHP(2);
            c.subtractHP(2);
        }else if (hero instanceof C){
            System.out.println("C发动技能:C回复两点HP,A、B扣除两点HP");
            c.addHP(2);
            b.subtractHP(2);
            a.subtractHP(2);
        }
    }
    public void setA(A a) {
        this.a = a;
    }
    public void setB(B b) {
        this.b = b;
    }
    public void setC(C c) {
        this.c = c;
    }
}

测试:

public static void main(String[] args) {
        GameMediator gameMediator = GameMediator.getGameMediator();
        A a = new A(gameMediator);
        gameMediator.setA(a);
        B b = new B(gameMediator);
        gameMediator.setB(b);
        C c = new C(gameMediator);
        gameMediator.setC(c);
        gameMediator.useSkill(a);
        a.printHP();
        b.printHP();
        c.printHP();
        gameMediator.useSkill(b);
        a.printHP();
        b.printHP();
        c.printHP();
    }

可以看到在上面的例子之中,我们将A、B、C三个对象全部交给调停者来管理,由他来控制发动技能这个过程,这样就避免了对象之间的相互耦合,但是缺点是调停者本身的代码会比较冗余。大量的if else判断可以考虑使用策略模式来优化。

目录
相关文章
|
设计模式 前端开发
设计模式21 - 中介者模式【【Mediator Pattern】
设计模式21 - 中介者模式【【Mediator Pattern】
51 0
|
设计模式 前端开发
设计模式~调停者(中介)模式-06
调停者(中介)模式 优点 缺点 使用场景 用一个中介对
59 0
|
6月前
|
设计模式 存储 前端开发
【设计模式】之调停者模式
调停者模式是一种有助于降低对象之间耦合度的设计模式。它通过引入一个调停者对象来集中处理一组对象之间的交互,使得代码更易于维护和扩展。在前端开发中,调停者模式可以应用于表单验证、消息订阅与发布、组件间通信等场景。尽管调停者模式可能会增加系统的复杂性,并且调停者对象可能变得庞大和复杂,但它仍然是一种有价值的设计模式,可以提高代码的可读性和可维护性。
65 0
【设计模式】之调停者模式
|
设计模式 前端开发 调度
设计模式~调停者(中介者)模式(Mediator)-21
用一个中介对象封装一系列的对象交互,中介者使各对象不需要显示地相互作用,从而使其耦合松散,而且可以独立地改变它们之间的交互。 调停者(中介者)模式(Mediator) (1)优点 (2)缺点 (3)使用场景 (4)注意事项: (5)应用实例: 代码
52 1
|
设计模式 前端开发 uml
认真学习设计模式之中介者模式(Mediator Pattern)
认真学习设计模式之中介者模式(Mediator Pattern)
65 0
|
设计模式 前端开发 Java
【设计模式——学习笔记】23种设计模式——中介者模式Mediator(原理讲解+应用场景介绍+案例介绍+Java代码实现)
【设计模式——学习笔记】23种设计模式——中介者模式Mediator(原理讲解+应用场景介绍+案例介绍+Java代码实现)
90 0
|
设计模式 前端开发 Java
Java中23种面试常考的设计模式之中介者模式(Mediator)---行为型模式
Java中23种面试常考的设计模式之中介者模式(Mediator)---行为型模式
90 1
|
设计模式 Java
Java设计模式-中介者模式(Mediator)
Java设计模式-中介者模式(Mediator)
|
13天前
|
设计模式 安全 Java
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
|
2月前
|
设计模式 数据库连接 PHP
PHP中的设计模式:提升代码的可维护性与扩展性在软件开发过程中,设计模式是开发者们经常用到的工具之一。它们提供了经过验证的解决方案,可以帮助我们解决常见的软件设计问题。本文将介绍PHP中常用的设计模式,以及如何利用这些模式来提高代码的可维护性和扩展性。我们将从基础的设计模式入手,逐步深入到更复杂的应用场景。通过实际案例分析,读者可以更好地理解如何在PHP开发中应用这些设计模式,从而写出更加高效、灵活和易于维护的代码。
本文探讨了PHP中常用的设计模式及其在实际项目中的应用。内容涵盖设计模式的基本概念、分类和具体使用场景,重点介绍了单例模式、工厂模式和观察者模式等常见模式。通过具体的代码示例,展示了如何在PHP项目中有效利用设计模式来提升代码的可维护性和扩展性。文章还讨论了设计模式的选择原则和注意事项,帮助开发者在不同情境下做出最佳决策。

热门文章

最新文章

  • 1
    C++一分钟之-设计模式:工厂模式与抽象工厂
    42
  • 2
    《手把手教你》系列基础篇(九十四)-java+ selenium自动化测试-框架设计基础-POM设计模式实现-下篇(详解教程)
    46
  • 3
    C++一分钟之-C++中的设计模式:单例模式
    53
  • 4
    《手把手教你》系列基础篇(九十三)-java+ selenium自动化测试-框架设计基础-POM设计模式实现-上篇(详解教程)
    37
  • 5
    《手把手教你》系列基础篇(九十二)-java+ selenium自动化测试-框架设计基础-POM设计模式简介(详解教程)
    61
  • 6
    Java面试题:结合设计模式与并发工具包实现高效缓存;多线程与内存管理优化实践;并发框架与设计模式在复杂系统中的应用
    56
  • 7
    Java面试题:设计模式在并发编程中的创新应用,Java内存管理与多线程工具类的综合应用,Java并发工具包与并发框架的创新应用
    40
  • 8
    Java面试题:如何使用设计模式优化多线程环境下的资源管理?Java内存模型与并发工具类的协同工作,描述ForkJoinPool的工作机制,并解释其在并行计算中的优势。如何根据任务特性调整线程池参数
    49
  • 9
    Java面试题:请列举三种常用的设计模式,并分别给出在Java中的应用场景?请分析Java内存管理中的主要问题,并提出相应的优化策略?请简述Java多线程编程中的常见问题,并给出解决方案
    105
  • 10
    Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
    75