Go和Java实现中介者模式

news/2024/11/10 1:21:44 标签: 设计模式, java, golang

Go和Java实现中介者模式

下面通过一个同事之间相互通信的例子来说明中介者模式的使用。

1、中介者模式

中介者模式是用来降低多个对象和类之间的通信复杂性。这种模式提供了一个中介类,该类通常处理不同类之间的

通信,并支持松耦合,使代码易于维护。中介者模式属于行为型模式。

  • 意图:用一个中介对象来封装一系列的对象交互,中介者使各对象不需要显式地相互引用,从而使其耦合松

    散,而且可以独立地改变它们之间的交互。

  • 主要解决:对象与对象之间存在大量的关联关系,这样势必会导致系统的结构变得很复杂,同时若一个对象发

    生改变,我们也需要跟踪与之相关联的对象,同时做出相应的处理。

  • 何时使用:多个类相互耦合,形成了网状结构。

  • 如何解决:将上述网状结构分离为星型结构。

  • 关键代码:对象 Colleague 之间的通信封装到一个类中单独处理。

  • 应用实例:1、中国加入 WTO 之前是各个国家相互贸易,结构复杂,现在是各个国家通过 WTO 来互相贸易。

    2、机场调度系统。 3、MVC 框架,其中C(控制器)就是 M(模型)和 V(视图)的中介者。

  • 优点:1、降低了类的复杂度,将一对多转化成了一对一。 2、各个类之间的解耦。 3、符合迪米特原则。

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

  • 使用场景:1、系统中对象之间存在比较复杂的引用关系,导致它们之间的依赖关系结构混乱而且难以复用该

    对象。 2、想通过一个中间类来封装多个类中的行为,而又不想生成太多的子类。

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

  • 适用性:

    一组对象以定义良好但是复杂的方式进行通信,产生的相互依赖关系结构混乱且难以理解。

    一个对象引用其他很多对象并且直接与这些对象通信,导致难以复现该对象。

    想定制一个分布在多个类中的行为,而又不想生成太多的子类。

2、Go实现中介者模式

package mediator

// ========== Colleague同事类 ==========
type Colleague interface {
	Send(string)
	Notify(string)
}
package mediator

import "fmt"

// ========== ColleagueA同事类A ==========
type ColleagueA struct {
	Mediator
}

func (colleagueA *ColleagueA) Send(message string) {
	colleagueA.Mediator.Send(message, colleagueA)
}

func (colleagueA *ColleagueA) Notify(message string) {
	fmt.Println("同事A得到信息:" + message)
}
package mediator

import "fmt"

// ========== ColleagueB同事类B ==========
type ColleagueB struct {
	Mediator
}

func (colleagueB *ColleagueB) Send(message string) {
	colleagueB.Mediator.Send(message, colleagueB)

}

func (colleagueB *ColleagueB) Notify(message string) {
	fmt.Println("同事B得到信息:" + message)

}
package mediator

// ========== Mediator中介者类 ==========
type Mediator interface {
	Send(string, Colleague)
}
package com.mediator;

// ========== ConcreteMediator ==========
public class ConcreteMediator extends Mediator{

    private ColleagueA colleagueA;

    private ColleagueB colleagueB;

    public void setColleagueA(ColleagueA colleagueA) {
        this.colleagueA = colleagueA;
    }

    public void setColleagueB(ColleagueB colleagueB) {
        this.colleagueB = colleagueB;
    }

    @Override
    public void send(String message, Colleague colleague) {
        if (colleague == colleagueA){
            colleagueB.notify(message);
        }else{
            colleagueA.notify(message);
        }
    }
}
package main

import . "proj/mediator"

func main() {
	concreteMediator := ConcreteMediator{}
	colleagueA := ColleagueA{Mediator: &concreteMediator}
	colleagueB := ColleagueB{Mediator: &concreteMediator}
	concreteMediator.SetColleagueA(colleagueA)
	concreteMediator.SetColleagueB(colleagueB)
	colleagueA.Send("吃过饭了没?")
	colleagueB.Send("没有呢,你打算请客吗?")
}
# 程序输出
同事A得到信息:吃过饭了没?
同事A得到信息:没有呢,你打算请客吗?

3、Java实现中介者模式

java">package com.mediator;

// ========== Colleague同事类 ==========
public abstract class Colleague {
    protected Mediator mediator;
    public Colleague(Mediator mediator){
        this.mediator = mediator;
    }

    public void send(String message){
        this.mediator.send(message,this);
    }
    public abstract void notify(String message);
}
java">package com.mediator;

// ========== ColleagueA同事类A ==========
public class ColleagueA extends Colleague{
    public ColleagueA(Mediator mediator) {
        super(mediator);
    }

    @Override
    public void notify(String message){
        System.out.println("同事A得到信息:"+message);
    }
}
java">package com.mediator;

// ========== ColleagueB同事类B ==========
public class ColleagueB extends Colleague{
    public ColleagueB(Mediator mediator) {
        super(mediator);
    }

    @Override
    public void notify(String message){
        System.out.println("同事B得到信息:"+message);
    }
}
java">package com.mediator;

// ========== Mediator中介者类 ==========
public abstract  class Mediator {
    public abstract void send(String message,Colleague colleague);
}
java">package com.mediator;

// ========== ConcreteMediator ==========
public class ConcreteMediator extends Mediator{

    private ColleagueA colleagueA;

    private ColleagueB colleagueB;

    public void setColleagueA(ColleagueA colleagueA) {
        this.colleagueA = colleagueA;
    }

    public void setColleagueB(ColleagueB colleagueB) {
        this.colleagueB = colleagueB;
    }

    @Override
    public void send(String message, Colleague colleague) {
        if (colleague == colleagueA){
            colleagueB.notify(message);
        }else{
            colleagueA.notify(message);
        }
    }
}
java">package com.mediator;

public class Test {
    public static void main(String[] args) {
        ConcreteMediator concreteMediator = new ConcreteMediator();
        ColleagueA colleagueA = new ColleagueA(concreteMediator);
        ColleagueB colleagueB = new ColleagueB(concreteMediator);
        concreteMediator.setColleagueA(colleagueA);
        concreteMediator.setColleagueB(colleagueB);
        colleagueA.send("吃过饭了没?");
        colleagueB.send("没有呢,你打算请客吗?");
    }
}
# 程序输出
同事B得到信息:吃过饭了没?
同事A得到信息:没有呢,你打算请客吗?

http://www.niftyadmin.cn/n/4937226.html

相关文章

VMware Workstation 如何启用复制粘贴

产品:VMware Workstation 16 Pro 版本:16.1.1 build-17801498 我们刚安装好的 VMware Workstation 会发现无法复制粘贴文件到虚拟机中,如下为解决方案: 1.点击 虚拟机,点击 安装 VMware Tools(T)...。 2.虚拟机下面会…

机器学习/深度学习需要掌握的linux基础命令

很多深度学习/机器学习/数据分析等领域(或者说大多数在Python环境下进行操作的领域)的初学者入门时是在Windows上进行学习,也得益于如Anaconda等工具把环境管理做的如此友善 但如果想在该领域继续深耕,一定会与Linux操作系统打交…

torch.profiler

什么是torch.profiler PyTorch Profiler 是一个工具,它允许在训练和推理期间收集性能指标。Profiler 的上下文管理器 API 可用于更好地了解哪些模型操作最昂贵,检查它们的输入形状和调用堆栈,研究设备内核活动并可视化执行跟踪。 性能指标&…

Springboot 设置统一的请求返回格式

现在开发过程中主要采用前后端分离的方式进行开发测试,也就是前端封装请求,后端提供标准的API接口服务。一般现在json 格式受到开发者们的青睐,学习过程中我们可以设置接口的返回类型,那么怎么做到设置统一的返回格式呢&#xff1…

数据结构顺序表和链表(超详细)

线性表: 线性表 ( linear list ) 是 n 个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使 用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串 ... 线性表在逻辑上是线性结构,也就…

C#中的enum枚举类型位运算

class A { [Flags] public enum Week { Monday 1 << 0,//1,0b_0000_0001, Tuesday 0x0002,//2,1<<1,0b_0000_0010, Wednesday 0b_0000_0100,//二进制数,4 Thursday 1 << 3,//8,0x08,在计算机中&#xff0c;…

【力扣每日一题】1572. 矩阵对角线元素的和 8.11打卡

文章目录 题目思路代码 题目 1572. 矩阵对角线元素的和 难度&#xff1a; 简单 描述&#xff1a; 给你一个正方形矩阵 mat&#xff0c;请你返回矩阵对角线元素的和。 请你返回在矩阵主对角线上的元素和副对角线上且不在主对角线上元素的和。 返回合并后的二叉树。 注意…

【算法题】2518. 好分区的数目

题目&#xff1a; 给你一个正整数数组 nums 和一个整数 k 。 分区 的定义是&#xff1a;将数组划分成两个有序的 组 &#xff0c;并满足每个元素 恰好 存在于 某一个 组中。如果分区中每个组的元素和都大于等于 k &#xff0c;则认为分区是一个好分区。 返回 不同 的好分区的…