C++如何实现高性能的观察者模式?(事件驱动架构设计)

std::function + std::vector 存回调,别手写链表

性能瓶颈常出在通知阶段的遍历开销和内存碎片上。手写双向链表看似“可控”,实际带来指针跳转、缓存不友好、删除时迭代器失效等问题。现代 C++ 更推荐用连续内存容器存 std::function 对象。

实操建议:

std::shared_ptr 管理观察者生命周期,别裸指针 + weak_ptr 检查

裸指针观察者容易悬空,而每轮通知前都调 lock() 再判空,会把热点路径拖慢 20%+(实测 clang 15 / x86-64)。更轻量的做法是让观察者自己管理生命周期,发布者只持 std::shared_ptr

实操建议:

事件通知不加锁?看场景:单线程高频用无锁,跨线程必须分离通道

90% 的误以为“观察者模式必须线程安全”,结果给每个 notify()std::mutex,吞掉 3~5 倍吞吐。真实情况是:线程模型决定同步策略,不是模式本身决定。

实操建议:

std::move 传事件对象,但别 move 所有东西

事件对象如果含大字段(如 std::vector 日志内容),按值传参会触发深拷贝;但盲目所有参数都 std::move,可能破坏 const 正确性或导致多次 move 后访问未定义行为。

实操建议:

最易被忽略的是事件对象的内存布局和对齐。如果事件里混用 booldoublestd::string,缓存行浪费比你预想的严重。高频路径上,优先用 POD 结构 + 手动 padding,别依赖编译器优化。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。