c++怎么实现一个观察者模式_c++事件通知与解耦机制实现

观察者模式通过Subject与Observer接口实现一对多依赖更新。1. Subject维护观察者列表,状态变化时通知所有Observer;2. Observer定义update纯虚函数接收通知;3. 使用智能指针与弱引用避免内存泄漏和悬挂指针;4. 加入互斥锁保障多线程安全;5. 适用于事件系统、日志广播等解耦场景。

c++怎么实现一个观察者模式_c++事件通知与解耦机制实现

观察者模式是一种行为设计模式,用于在对象之间建立一对多的依赖关系,当一个对象状态改变时,所有依赖它的对象都会收到通知并自动更新。在C++中,这种机制常被用来实现事件通知系统,达到模块间的解耦。

核心思路与角色划分

观察者模式包含两个主要角色:

Subject(被观察者):维护观察者列表,提供注册、注销和通知接口。Observer(观察者):定义接收通知的接口,通常是一个纯虚函数。

通过抽象接口,Subject不需要知道具体是谁在监听,实现了发送方与接收方的解耦。

基础实现示例

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

立即学习“C++免费学习笔记(深入)”;

#include #include #include 

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

// 被观察者class Subject {private:std::vector observers;

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

void detach(Observer* obs) {    observers.erase(        std::remove(observers.begin(), observers.end(), obs),        observers.end()    );}void notify(const std::string& message) {    for (auto* obs : observers) {        obs->update(message);    }}

};

定义两个具体的观察者:

class ConcreteObserverA : public Observer {public:    void update(const std::string& message) override {        std::cout << "Observer A received: " << message << "n";    }};

class ConcreteObserverB : public Observer {public:void update(const std::string& message) override {std::cout << "Observer B received: " << message << "n";}};

使用方式:

int main() {    Subject subject;    ConcreteObserverA observerA;    ConcreteObserverB observerB;
subject.attach(&observerA);subject.attach(&observerB);subject.notify("Hello Observers!");subject.detach(&observerA);subject.notify("Only B should see this.");return 0;

}

改进:支持多线程与智能指针

上面的实现存在裸指针管理问题。实际项目中建议使用std::weak_ptr避免悬挂指针,并考虑线程安全。

改用std::shared_ptrstd::weak_ptr

#include #include 

class Observer;

class Subject {private:std::list<std::weak_ptr> observers;mutable std::mutex mtx; // 线程安全

public:void attach(std::shared_ptr obs) {std::lock_guard lock(mtx);observers.remove_if([](const auto& w) { return w.expired(); });observers.push_back(obs);}

void notify(const std::string& message) {    std::lock_guard lock(mtx);    observers.remove_if([&](const auto& w) {        if (auto obs = w.lock()) {            obs->update(message);            return false;        }        return true; // 已过期,移除    });}

};

观察者也改为继承 enable_shared_from_this:

class Observer : public std::enable_shared_from_this {public:    virtual ~Observer() = default;    virtual void update(const std::string& message) = 0;};

应用场景与优势

观察者模式适合以下场景:

GUI事件系统(按钮点击、窗口关闭)消息广播机制日志系统多输出目标游戏中的事件驱动逻辑

优点包括:

松耦合:Subject不依赖具体Observer可扩展:新增观察者无需修改现有代码动态订阅:运行时灵活添加或移除监听者

基本上就这些。关键是理解“发布-订阅”思想,用接口隔离变化,再结合现代C++特性提升安全性和可用性。实际项目中也可考虑使用信号槽库(如Boost.Signals2)来简化实现。

以上就是c++++怎么实现一个观察者模式_c++事件通知与解耦机制实现的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1484969.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 08:31:03
下一篇 2025年12月8日 18:21:45

相关推荐

发表回复

登录后才能评论
关注微信