C++中的观察者模式

目录

[观察者模式(Observer Pattern)](#观察者模式(Observer Pattern))

实际应用

股票价格监控系统

发布-订阅系统

总结


观察者模式(Observer Pattern)

观察者模式是一种行为型设计模式,它定义了对象间的一对多依赖关系。当一个对象的状态发生改变时,所有依赖于它的对象都会得到通知并自动更新。观察者模式主要包含以下角色:

  1. Subject (主题):保存对观察者的引用,并提供注册和注销观察者的方法。

  2. Observer (观察者):定义一个更新接口,用于接收主题的通知。

  3. ConcreteSubject (具体主题):具体实现主题,维护其状态并在状态改变时通知观察者。

  4. ConcreteObserver(具体观察者):具体实现观察者,响应主题的通知并进行相应的更新。

实际应用

股票价格监控系统

-- 实现一个股票价格监控系统,当股票价格发生变化时,所有注册的观察者(例如投资者)都会收到通知。

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

// 观察者接口
class Observer {
public:
    virtual void update(const std::string& stockName, float price) = 0;
};

// 主题接口
class Subject {
public:
    virtual void registerObserver(std::shared_ptr<Observer> observer) = 0;
    virtual void removeObserver(std::shared_ptr<Observer> observer) = 0;
    virtual void notifyObservers() = 0;
};

// 具体主题
class Stock : public Subject {
private:
    std::string name;
    float price;
    std::vector<std::shared_ptr<Observer>> observers;

public:
    Stock(const std::string& name, float price) : name(name), price(price) {}

    void setPrice(float newPrice) {
        price = newPrice;
        notifyObservers();
    }

    float getPrice() const {
        return price;
    }

    void registerObserver(std::shared_ptr<Observer> observer) override {
        observers.push_back(observer);
    }

    void removeObserver(std::shared_ptr<Observer> observer) override {
        observers.erase(std::remove(observers.begin(), observers.end(), observer), observers.end());
    }

    void notifyObservers() override {
        for (auto& observer : observers) {
            observer->update(name, price);
        }
    }
};

// 具体观察者
class Investor : public Observer {
private:
    std::string name;

public:
    Investor(const std::string& name) : name(name) {}

    void update(const std::string& stockName, float price) override {
        std::cout << "Investor " << name << " is notified that " << stockName << " price changed to " << price << std::endl;
    }
};

// 客户端代码
int main() {
    auto stock = std::make_shared<Stock>("AAPL", 150.0);

    auto investor1 = std::make_shared<Investor>("Alice");
    auto investor2 = std::make_shared<Investor>("Bob");

    stock->registerObserver(investor1);
    stock->registerObserver(investor2);

    stock->setPrice(155.0);
    stock->setPrice(160.0);

    stock->removeObserver(investor1);
    stock->setPrice(165.0);

    return 0;
}

发布-订阅系统

-- 实现一个简单的发布-订阅系统,当发布者发布新消息时,所有订阅者都会收到通知。

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

// 观察者接口
class Subscriber {
public:
    virtual void update(const std::string& message) = 0;
};

// 主题接口
class Publisher {
public:
    virtual void registerSubscriber(std::shared_ptr<Subscriber> subscriber) = 0;
    virtual void removeSubscriber(std::shared_ptr<Subscriber> subscriber) = 0;
    virtual void notifySubscribers() = 0;
};

// 具体主题
class NewsPublisher : public Publisher {
private:
    std::string latestNews;
    std::vector<std::shared_ptr<Subscriber>> subscribers;

public:
    void publishNews(const std::string& news) {
        latestNews = news;
        notifySubscribers();
    }

    void registerSubscriber(std::shared_ptr<Subscriber> subscriber) override {
        subscribers.push_back(subscriber);
    }

    void removeSubscriber(std::shared_ptr<Subscriber> subscriber) override {
        subscribers.erase(std::remove(subscribers.begin(), subscribers.end(), subscriber), subscribers.end());
    }

    void notifySubscribers() override {
        for (auto& subscriber : subscribers) {
            subscriber->update(latestNews);
        }
    }
};

// 具体观察者
class ConcreteSubscriber : public Subscriber {
private:
    std::string name;

public:
    ConcreteSubscriber(const std::string& name) : name(name) {}

    void update(const std::string& message) override {
        std::cout << "Subscriber " << name << " received: " << message << std::endl;
    }
};

// 客户端代码
int main() {
    auto publisher = std::make_shared<NewsPublisher>();

    auto subscriber1 = std::make_shared<ConcreteSubscriber>("Alice");
    auto subscriber2 = std::make_shared<ConcreteSubscriber>("Bob");

    publisher->registerSubscriber(subscriber1);
    publisher->registerSubscriber(subscriber2);

    publisher->publishNews("Breaking News: Observer Pattern in Action!");
    publisher->publishNews("Latest Update: New Design Patterns Discovered!");

    publisher->removeSubscriber(subscriber1);
    publisher->publishNews("Exclusive: Observer Pattern Simplified!");

    return 0;
}

总结

观察者模式帮助我们定义了对象间的一对多依赖关系,使得对象之间的通信变得更加灵活和可扩展。

相关推荐
菜鸡且互啄6934 分钟前
在线教育平台,easyexcel使用案例
java·开发语言
电饭叔2 小时前
《python程序语言设计》2018版第5章第52题利用turtle绘制sin函数
开发语言·python
weixin_452600692 小时前
如何为老化的汽车铅酸电池充电
开发语言·单片机·安全·汽车·电机·电源模块·充电桩
Java资深爱好者3 小时前
如何在std::map中查找元素
开发语言·c++
YCCX_XFF213 小时前
ImportError: DLL load failed while importing _imaging: 操作系统无法运行 %1
开发语言·python
哥廷根数学学派4 小时前
基于Maximin的异常检测方法(MATLAB)
开发语言·人工智能·深度学习·机器学习
杰哥在此5 小时前
Java面试题:讨论持续集成/持续部署的重要性,并描述如何在项目中实施CI/CD流程
java·开发语言·python·面试·编程
Unity打怪升级5 小时前
Laravel: 优雅构建PHP应用的现代框架
开发语言·php·laravel
C.C5 小时前
java IO流(1)
java·开发语言
安步当歌6 小时前
【FFmpeg】av_write_trailer函数
c语言·c++·ffmpeg·视频编解码·video-codec