C++轻量级线程安全发布-订阅系统由Publisher、Subscriber和MessageCenter三部分构成,通过字符串主题解耦模块,用mutex保护订阅表、消息队列实现发布与分发分离,支持泛型模板和值拷贝/智能指针管理数据生命周期。

用C++实现一个简单的发布-订阅系统,核心是让模块之间不直接调用、不互相持有指针,靠“主题(Topic)”中转消息。它不是必须用网络或第三方库,纯内存+线程安全的轻量级设计就能满足多数本地模块通信需求。
一个可运行的最小Pub/Sub系统,至少包含:
Publish("topic_name", data),不关心谁收、收几次Subscribe("topic_name") 表达兴趣,再实现自己的 OnMessage() 处理逻辑常见误区是给整个 Publish() 加大锁,导致高频发布时阻塞严重。更合理的做法是:
std::mutex 保护内部映射表(std::map<:string std::vector>></:string>)std::queue<msgpack></msgpack>),只锁入队那段初学者容易纠结“该不该用 std::type_info 当主题”。实际开发中,字符串主题更灵活:
立即学习“C++免费学习笔记(深入)”;
"ui.health_bar" 或 "cfg.language"
template<typename t> void Publish(const std::string& topic, const T& data);</typename>
内部自动序列化为 std::vector<char></char> + 类型名哈希,订阅端按需反解std::shared_ptr 管理生命周期下面这段是真正能编译运行的骨架(已省略头文件和细节错误处理):
class MessageCenter {
static MessageCenter* s_instance;
std::mutex m_sub_mutex;
std::map<std::string, std::vector<std::function<void(void*)>>> m_subs;
public:
static MessageCenter& Get() { return *s_instance; }
void Subscribe(const std::string& t, std::function<void(void*)> cb) {
std::lock_guard<std::mutex> lk(m_sub_mutex);
m_subs[t].push_back(cb);
}
void Publish(const std::string& t, void* data) {
auto it = m_subs.find(t);
if (it != m_subs.end())
for (auto& cb : it->second) cb(data);
}
};
使用时:MessageCenter::Get().Subscribe("player.hit", [](void* d){ /* 播放音效 */ });MessageCenter::Get().Publish("player.hit", &damage_value);
基本上就这些。不需要宏、不依赖外部构建系统,编译进任意C++17项目都能立刻用上。重点不在代码行数,而在“谁发、谁收、谁中转”三者职责彻底分开。
以上就是c++++如何实现一个简单的发布订阅系统_c++ Pub/Sub模式与消息队列【设计】的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号