zeromq学习记录(七)订阅发布消息封装
之前也有提到 使用订阅发布 pub sub模式必须要显示定义ZMQ_SUBSCRIBE
只有以此模式定义的过滤字节开头的消息才会被订阅者收到
如果想收到所有信息
可定义subscriber.setsockopt(ZMQ_SUBSCRIBE, "", 0); 此类过滤器
示例很简单 我将示例代码发布者与订阅者整合到一个工程中 开启两个线程演示
上代码

// psenvpubsub.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include "zhelpers.hpp" #include <thread> void PubFunc() { zmq::context_t context(1); zmq::socket_t publisher(context, ZMQ_PUB); publisher.bind("tcp://*:5563"); while (1) { // Write two messages, each with an envelope and content s_sendmore(publisher, "A"); s_send(publisher, "We don't want to see this"); s_sendmore(publisher, "B"); s_send(publisher, "We would like to see this"); Sleep(1000); } return; } void SubFunc() { zmq::context_t context(1); zmq::socket_t subscriber(context, ZMQ_SUB); subscriber.connect("tcp://localhost:5563"); subscriber.setsockopt(ZMQ_SUBSCRIBE, "B", 1); while (1) { // Read envelope with address std::string address = s_recv(subscriber); // Read message contents std::string contents = s_recv(subscriber); std::cout << "[" << address << "] " << contents << std::endl; } } int main() { //开启两个线程 一个发 一个收 // 用于演示发布者的封包发送及订阅者的过滤使用 std::thread threadPub = std::thread(PubFunc); std::thread threadSub = std::thread(SubFunc); threadPub.join(); threadSub.join(); return 0; }
作 者: itdef
欢迎转帖 请保持文本完整并注明出处
技术博客 http://www.cnblogs.com/itdef/
B站算法视频题解
https://space.bilibili.com/18508846
qq 151435887
gitee https://gitee.com/def/
欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
如果觉得不错,欢迎点赞,你的鼓励就是我的动力
欢迎转帖 请保持文本完整并注明出处
技术博客 http://www.cnblogs.com/itdef/
B站算法视频题解
https://space.bilibili.com/18508846
qq 151435887
gitee https://gitee.com/def/
欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
如果觉得不错,欢迎点赞,你的鼓励就是我的动力


【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步