【C++设计模式】行为型模式:观察者模式

文章目录

行为型模式:观察者模式

观察者模式定义了一种一对多的依赖关系:它让一个主题(被观察者)对象关联多个观察者对象,并且当主题对象的状态发生变化时,它会主动通知这些观察者对象,使它们能够自动更新自己或执行相应的响应操作。

以一个设备的温度显示系统为例,在这个示例中,温度检测仪是被观察者,当设备温度发生变化时,它会通知所有的显示器更新温度信息。

cpp 复制代码
#include <iostream>
#include <vector>
#include <string>
#include <algorithm> 

// 观察者接口
class IObserver {
public:
    virtual void update(float temperature) = 0;
    virtual ~IObserver() {}
};

// 主题接口(Subject)
class ISubject {
public:
    virtual void registerObserver(IObserver* observer) = 0;
    virtual void removeObserver(IObserver* observer) = 0;
    virtual void notifyObservers() = 0;
    virtual ~ISubject() {}
};

// 被观察者类:设备温度检测仪
class DeviceTemperatureMonitor : public ISubject {
private:
    std::vector<IObserver*> observers;
    float temperature;

public:
    // 注册观察者
    void registerObserver(IObserver* observer) override {
        observers.push_back(observer);
    }

    // 移除观察者
    void removeObserver(IObserver* observer) override {
    // std::remove将所有与指定值observer相等的元素移动到容器的末尾,并返回指向第一个不需要保留的元素的迭代器
        observers.erase(std::remove(observers.begin(), observers.end(), observer), observers.end());
    }

    // 通知所有观察者
    void notifyObservers() override {
        for (IObserver* observer : observers) {
            observer->update(temperature);
        }
    }

    // 设置温度状态并通知所有观察者
    void setTemperature(float temp) {
        temperature = temp;
        notifyObservers();
    }
};

// 观察者类:手机显示器
class PhoneDisplay : public IObserver {
private:
    std::string deviceName;

public:
    PhoneDisplay(const std::string& name) : deviceName(name) {}

    void update(float temperature) override {
        std::cout << "Phone Display (" << deviceName << ") - Device Temperature: " 
                  << temperature << "°C\n";
    }
};

// 观察者类:窗口显示器
class WindowDisplay : public IObserver {
private:
    std::string location;

public:
    WindowDisplay(const std::string& loc) : location(loc) {}

    void update(float temperature) override {
        std::cout << "Window Display at " << location << " - Device Temperature: " 
                  << temperature << "°C\n";
    }
};

int main() {
    // 创建被观察者对象(设备温度检测仪)
    DeviceTemperatureMonitor tempMonitor;

    // 创建观察者对象(显示设备)
    PhoneDisplay phoneDisplay1("iPhone");
    PhoneDisplay phoneDisplay2("Samsung");
    WindowDisplay windowDisplay("Office");

    // 注册观察者
    tempMonitor.registerObserver(&phoneDisplay1);
    tempMonitor.registerObserver(&phoneDisplay2);
    tempMonitor.registerObserver(&windowDisplay);

    // 模拟温度数据更新
    std::cout << "Temperature Update 1:\n";
    tempMonitor.setTemperature(75.0f);

    std::cout << "\nTemperature Update 2:\n";
    tempMonitor.setTemperature(80.0f);

    // 移除一个观察者
    tempMonitor.removeObserver(&phoneDisplay2);

    std::cout << "\nTemperature Update 3 (After removing Samsung Phone Display):\n";
    tempMonitor.setTemperature(85.0f);

    return 0;
}
复制代码
Temperature Update 1:
Phone Display (iPhone) - Device Temperature: 75°C
Phone Display (Samsung) - Device Temperature: 75°C
Window Display at Office - Device Temperature: 75°C

Temperature Update 2:
Phone Display (iPhone) - Device Temperature: 80°C
Phone Display (Samsung) - Device Temperature: 80°C
Window Display at Office - Device Temperature: 80°C

Temperature Update 3 (After removing Samsung Phone Display):
Phone Display (iPhone) - Device Temperature: 85°C
Window Display at Office - Device Temperature: 85°C
相关推荐
筏.k19 分钟前
智能指针入门:深入理解 C++ 的 shared_ptr
开发语言·c++·c#11.0
陌尘(MoCheeen)1 小时前
技术书籍推荐(002)
java·javascript·c++·python·go
Wooden-Flute1 小时前
十二、操作符重载
c++
huangyuchi.1 小时前
【C++】智能指针
开发语言·jvm·c++·笔记·c++11·智能指针·shared_ptr
南玖yy2 小时前
C/C++ 内存管理深度解析:从内存分布到实践应用(malloc和new,free和delete的对比与使用,定位 new )
c语言·开发语言·c++·笔记·后端·游戏引擎·课程设计
李匠20242 小时前
C++GO语言微服务基础技术②
开发语言·c++·微服务·golang
Cuit小唐2 小时前
C++ 状态模式详解
开发语言·c++·状态模式
Funny-Boy3 小时前
std::move 和 std::forward
c++
落羽的落羽3 小时前
【落羽的落羽 C++】stack和queue、deque、priority_queue、仿函数
开发语言·c++
刃神太酷啦3 小时前
类和对象(1)--《Hello C++ Wrold!》(3)--(C/C++)
java·c语言·c++·git·算法·leetcode·github