ZeroMQ C++ 客户端没有收到
ZeroMQ C++ client is not receiving
我最近用 Pupil eyetracker. To broadcast the tracking information to additional clients they use ZeroMQ 开始了一个新项目。我通过尝试简单的 Python 客户端示例验证了他们的服务器 运行 正确:
import zmq
import json
#network setup
port = "5000"
context = zmq.Context()
socket = context.socket(zmq.SUB)
socket.connect("tcp://127.0.0.1:"+port)
# recv all messages
socket.setsockopt(zmq.SUBSCRIBE, '')
while True:
topic = socket.recv_multipart()
#msg = json.loads(topic)
print "\n\n",topic[0] #,":\n",msg
因为我的项目应该是 C++,所以我尝试使用 ZeroMQ 示例将其翻译成 C++,如下所示:
#include "zmq.hpp"
#include <string>
#include <iostream>
int main()
{
// Prepare our context and socket
zmq::context_t context(1);
zmq::socket_t socket(context, ZMQ_SUB);
std::cout << "Connecting to hello world server" << std::endl;
socket.connect("tcp://127.0.0.1:5000");
socket.setsockopt(ZMQ_SUBSCRIBE, "");
// Do 100 requests, waiting each time for a response
for (int request_nbr = 0; request_nbr != 100; request_nbr++) {
// Get the message.
zmq::message_t msg;
socket.recv(&msg);
std::cout << "Received World " << msg.data() << std::endl;
}
return 0;
}
不幸的是,这不起作用,C++ 客户端只是挂在 socket.recv(&msg);等待它从未收到的消息。
对于我使用的项目 Visual Studio 2013 和 ZeroMQ 安装附带的 ZeroMQ 库 libzmq-v120-mt-4_0_4.lib(我没有编译它)。为了设置它,我使用了 this 教程,没有粘贴整个教程,因为我觉得它有点无关紧要。
我使用的配置是 x64 而 Pupil 的是 32 位,我想,但如果我没记错的话这应该与 ZeroMQ 无关。
学生使用 pyzmq,它应该与 4.04 zmq 库兼容。
出于某种原因,我仍然不知道,包装器 zmq.hpp 在我的情况下不起作用。使用来自 book 的解决方案,它不使用这个助手解决了我的问题
int main(int argc, char *argv[])
{
void *context = zmq_ctx_new();
// Socket to talk to server
void *subscriber = zmq_socket(context, ZMQ_SUB);
int rc = zmq_connect(subscriber, "tcp://127.0.0.1:5000");
assert(rc == 0);
rc = zmq_setsockopt(subscriber, ZMQ_SUBSCRIBE, "", strlen(""));
assert(rc == 0);
// Process 100 updates
int update_nbr;
long total_temp = 0;
for (update_nbr = 0; update_nbr < 100; update_nbr++) {
char msg[256];
rc = zmq_recv(subscriber, msg, 256, 0);
std::cout << "Received World " << msg << std::endl;
}
zmq_close(subscriber);
zmq_ctx_destroy(context);
return 0;
}
我最近用 Pupil eyetracker. To broadcast the tracking information to additional clients they use ZeroMQ 开始了一个新项目。我通过尝试简单的 Python 客户端示例验证了他们的服务器 运行 正确:
import zmq
import json
#network setup
port = "5000"
context = zmq.Context()
socket = context.socket(zmq.SUB)
socket.connect("tcp://127.0.0.1:"+port)
# recv all messages
socket.setsockopt(zmq.SUBSCRIBE, '')
while True:
topic = socket.recv_multipart()
#msg = json.loads(topic)
print "\n\n",topic[0] #,":\n",msg
因为我的项目应该是 C++,所以我尝试使用 ZeroMQ 示例将其翻译成 C++,如下所示:
#include "zmq.hpp"
#include <string>
#include <iostream>
int main()
{
// Prepare our context and socket
zmq::context_t context(1);
zmq::socket_t socket(context, ZMQ_SUB);
std::cout << "Connecting to hello world server" << std::endl;
socket.connect("tcp://127.0.0.1:5000");
socket.setsockopt(ZMQ_SUBSCRIBE, "");
// Do 100 requests, waiting each time for a response
for (int request_nbr = 0; request_nbr != 100; request_nbr++) {
// Get the message.
zmq::message_t msg;
socket.recv(&msg);
std::cout << "Received World " << msg.data() << std::endl;
}
return 0;
}
不幸的是,这不起作用,C++ 客户端只是挂在 socket.recv(&msg);等待它从未收到的消息。
对于我使用的项目 Visual Studio 2013 和 ZeroMQ 安装附带的 ZeroMQ 库 libzmq-v120-mt-4_0_4.lib(我没有编译它)。为了设置它,我使用了 this 教程,没有粘贴整个教程,因为我觉得它有点无关紧要。
我使用的配置是 x64 而 Pupil 的是 32 位,我想,但如果我没记错的话这应该与 ZeroMQ 无关。
学生使用 pyzmq,它应该与 4.04 zmq 库兼容。
出于某种原因,我仍然不知道,包装器 zmq.hpp 在我的情况下不起作用。使用来自 book 的解决方案,它不使用这个助手解决了我的问题
int main(int argc, char *argv[])
{
void *context = zmq_ctx_new();
// Socket to talk to server
void *subscriber = zmq_socket(context, ZMQ_SUB);
int rc = zmq_connect(subscriber, "tcp://127.0.0.1:5000");
assert(rc == 0);
rc = zmq_setsockopt(subscriber, ZMQ_SUBSCRIBE, "", strlen(""));
assert(rc == 0);
// Process 100 updates
int update_nbr;
long total_temp = 0;
for (update_nbr = 0; update_nbr < 100; update_nbr++) {
char msg[256];
rc = zmq_recv(subscriber, msg, 256, 0);
std::cout << "Received World " << msg << std::endl;
}
zmq_close(subscriber);
zmq_ctx_destroy(context);
return 0;
}