首页 关于我们 成功案例 网络营销 电商设计 新闻中心 联系方式
QQ联系
电话联系
手机联系

c++中如何实现一个观察者模式_Observer设计模式的实现思路与代码示例

发布时间:2025-11-02 22:17
发布者:网络
浏览次数:
观察者模式通过Subject维护Observer列表实现一对多依赖,当状态变化时自动通知所有观察者;代码中ConcreteSubject用vector存储Observer指针,调用notify遍历执行update,输出显示注册的观察者接收消息,移除后不再通知。

c++中如何实现一个观察者模式_observer设计模式的实现思路与代码示例

在C++中实现观察者模式(Observer Pattern),核心是定义一种一对多的依赖关系,让多个观察者对象同时监听一个主题对象。当主题状态发生变化时,所有注册的观察者都会自动收到通知并更新。

观察者模式的核心角色

Subject(被观察者):维护观察者列表,提供注册、注销和通知接口。
Observer(观察者):定义接收通知的接口,通常是一个纯虚函数。
当主题状态改变时,调用通知方法,遍历所有观察者并调用其更新函数。

实现步骤与代码示例

下面是一个简洁但完整的C++实现:

#include <iostream>
#include <vector>
#include <algorithm>
<p>// 观察者接口
class Observer {
public:
virtual ~Observer() = default;
virtual void update(const std::string& message) = 0;
};</p><p>// 被观察者接口
class Subject {
public:
virtual ~Subject() = default;
virtual void attach(Observer<em> obs) = 0;
virtual void detach(Observer</em> obs) = 0;
virtual void notify(const std::string& message) = 0;
};</p><p>// 具体被观察者
class ConcreteSubject : public Subject {
private:
std::vector<Observer*>; observers;
std::string state;</p><p>public:
void setState(const std::string& s) {
state = s;
notify(state);
}</p><pre class='brush:php;toolbar:false;'>std::string getState() const {
    return state;
}

void attach(Observer* obs) override {
    observers.push_back(obs);
}

void detach(Observer* obs) override {
    observers.erase(
        std::remove(observers.begin(), observers.end(), obs),
        observers.end()
    );
}

void notify(const std::string& message) override {
    for (Observer* obs : observers) {
        obs->update(message);
    }
}

};

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

public: ConcreteObserver(const std::string& n) : name(n) {}

void update(const std::string& message) override {
    std::cout << name << " 收到通知: " << message << "\n";
}

};

使用示例

演示如何注册观察者并触发通知:

Musho Musho

AI网页设计Figma插件

Musho 76 查看详情 Musho

int main() {
    ConcreteSubject subject;
<pre class='brush:php;toolbar:false;'>ConcreteObserver observer1("观察者A");
ConcreteObserver observer2("观察者B");

subject.attach(&observer1);
subject.attach(&observer2);

subject.setState("系统状态已更新!");

subject.detach(&observer2);

subject.setState("第二次更新,只有A会收到");

return 0;

}

输出结果:
观察者A 收到通知: 系统状态已更新!
观察者B 收到通知: 系统状态已更新!
观察者A 收到通知: 第二次更新,只有A会收到

关键细节说明

使用裸指针时需确保观察者生命周期长于被观察者,否则可能引发悬空指针。若需更安全的管理,可改用智能指针(如std::weak_ptr)结合信号槽机制,或使用std::shared_ptr配合enable_shared_from_this。

基本上就这些。这种实现方式简单直观,适合理解模式本质,也可根据项目需求扩展支持异步通知、事件过滤等功能。

以上就是c++++中如何实现一个观察者模式_Observer设计模式的实现思路与代码示例的详细内容,更多请关注其它相关文章!


# go  # ai  # c++  # ios  # stream  # red  # 如何实现  # 都是  # 是一个  # 遍历  # 尼克  # 何为  # 管理机制  # 多路  # 复用  # 多个  # 如何推广网站优化  # 抖音怎样营销推广  # 滨湖区线上推广招聘网站  # 广西新网站建设费用  # 东莞机械网站优化  # 营销推广诱导老人消费的措施  # 数据查询网站建设  # 互联网营销推广去哪家  # 天水抖音seo排名  # 智能推广素材库网站