您的位置 首页 编程知识

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

观察者模式通过Subject维护Observer列表实现一对多依赖,当状态变化时自动通知所有观察者;代码中Co…


观察者模式通过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"; }
登录后复制

};

立即学习“”;

使用示例

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

最懂设计师的效率提升平台,实现高效设计出图和智能改图,室内设计,毛坯渲染,旧房改造 ,软装设计

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

 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::sha_ptr配合enable_shared_from_this。

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

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

相关标签:

大家都在看:

本文来自网络,不代表四平甲倪网络网站制作专家立场,转载请注明出处:http://www.elephantgpt.cn/16163.html

作者: nijia

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

联系我们

联系我们

18844404989

在线咨询: QQ交谈

邮箱: 641522856@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部