大话设计模式之中介者模式

中介者模式是一种行为型设计模式,它通过引入一个中介者对象来封装一系列对象之间的交互,从而减少对象之间的直接通信,使得对象之间的耦合度降低,同时提高了系统的可维护性和灵活性。

在中介者模式中,对象之间的通信不再直接发生,而是通过中介者对象来进行。当一个对象需要与其他对象进行交互时,它不会直接与其他对象通信,而是将请求发送给中介者对象,由中介者对象负责将请求传递给合适的对象,并且可以在必要时对请求进行转发、过滤或者其他处理。

中介者模式通常包含以下几个角色:

  • 中介者(Mediator):定义一个接口用于与各个同事对象通信。
  • 具体中介者(Concrete Mediator):实现中介者接口,负责协调各个同事对象的交互关系。
  • 同事(Colleague):定义一个接口用于与中介者对象通信。
  • 具体同事(Concrete Colleague):实现同事接口,并与其他同事对象交互。
cpp 复制代码
#include <iostream>
#include <string>
#include <vector>

// 前置声明
class Mediator;

// 同事抽象类
class Colleague {
public:
    virtual ~Colleague() {}
    virtual void send(const std::string& message) const = 0;
    virtual void receive(const std::string& message) const = 0;
    virtual void setMediator(Mediator* mediator) {
        mediator_ = mediator;
    }

protected:
    Mediator* mediator_;
};

// 具体同事类 A
class ConcreteColleagueA : public Colleague {
public:
    void send(const std::string& message) const override {
        mediator_->distributeMessage(this, message);
    }

    void receive(const std::string& message) const override {
        std::cout << "Concrete Colleague A received: " << message << std::endl;
    }
};

// 具体同事类 B
class ConcreteColleagueB : public Colleague {
public:
    void send(const std::string& message) const override {
        mediator_->distributeMessage(this, message);
    }

    void receive(const std::string& message) const override {
        std::cout << "Concrete Colleague B received: " << message << std::endl;
    }
};

// 中介者抽象类
class Mediator {
public:
    virtual ~Mediator() {}
    virtual void distributeMessage(const Colleague* sender, const std::string& message) const = 0;
};

// 具体中介者类
class ConcreteMediator : public Mediator {
public:
    void addColleague(Colleague* colleague) {
        colleagues_.push_back(colleague);
    }

    void distributeMessage(const Colleague* sender, const std::string& message) const override {
        for (const auto& colleague : colleagues_) {
            if (colleague != sender) {
                colleague->receive(message);
            }
        }
    }

private:
    std::vector<Colleague*> colleagues_;
};

int main() {
    ConcreteColleagueA colleagueA;
    ConcreteColleagueB colleagueB;

    ConcreteMediator mediator;
    mediator.addColleague(&colleagueA);
    mediator.addColleague(&colleagueB);

    colleagueA.setMediator(&mediator);
    colleagueB.setMediator(&mediator);

    colleagueA.send("Hello from Colleague A");
    colleagueB.send("Hi from Colleague B");

    return 0;
}

/*
在这个示例中,Colleague 是同事抽象类,定义了发送和接收消息的接口,并维护了一个中介者指针。ConcreteColleagueA 和 ConcreteColleagueB 是具体的同事类,实现了同事接口。Mediator 是中介者抽象类,定义了分发消息的接口。ConcreteMediator 是具体的中介者类,负责协调各个同事对象之间的消息传递。在 main() 函数中,我们创建了具体的同事对象和中介者对象,并设置了它们之间的关系,然后通过同事对象向中介者发送消息。
*/

觉得有帮助的话,打赏一下呗。。

相关推荐
闲人一枚(学习中)2 小时前
设计模式-创建型-抽象工厂模式
设计模式·抽象工厂模式
小白不太白9504 小时前
设计模式之 观察者模式
观察者模式·设计模式
小白不太白9505 小时前
设计模式之 责任链模式
python·设计模式·责任链模式
吾与谁归in6 小时前
【C#设计模式(13)——代理模式(Proxy Pattern)】
设计模式·c#·代理模式
吾与谁归in6 小时前
【C#设计模式(14)——责任链模式( Chain-of-responsibility Pattern)】
设计模式·c#·责任链模式
闲人一枚(学习中)6 小时前
设计模式-创建型-原型模式
设计模式
Iced_Sheep6 小时前
干掉 if else 之策略模式
后端·设计模式
哪 吒14 小时前
最简单的设计模式,抽象工厂模式,是否属于过度设计?
设计模式·抽象工厂模式
Theodore_102214 小时前
4 设计模式原则之接口隔离原则
java·开发语言·设计模式·java-ee·接口隔离原则·javaee
转世成为计算机大神17 小时前
易考八股文之Java中的设计模式?
java·开发语言·设计模式