c – 如何使用ZeroMQ接收多部分消息?

我无法获得ZeroMQ C包装器来接收多部分消息.使用C版本的相同代码工作正常,但它导致一个例外,C根本没有解释.多部分处理代码如下:

int _tmain(int argc, _TCHAR* argv[])
{
    zmq::context_t context(1);
    zmq::socket_t socket(context, ZMQ_REP);
    socket.bind("tcp://*:5555");

    while(true) {
        // the following two lines lead to exception
        zmq::message_t request;
        socket.recv(&request);

        //zmq_msg_t message;
        //zmq_msg_init (&message);
        //zmq_recv (socket, &message, 0);   
    }

    return 0;
}

这非常简单;这个版本不起作用.但是如果我在while循环中注释掉前两行并取消注释当前注释的(C版本)代码,它就可以工作.
这是Windows XP sp3,Zeromq 2.1.1和Visual Studio 2010 Express.

如果我发送单个部分消息,两个版本都可以正常工作.
我究竟做错了什么?

最佳答案 可能C版本的代码也不起作用,但你没有检查zmq_recv的返回代码,所以你没有注意到它.此外,在接收miltipart消息时,您应该检查是否有更多消息部分要通过套接字接收,如下所示:

int64_t more = 0;
size_t more_size = sizeof(more);
socket.getsockopt(ZMQ_RCVMORE, &more, &more_size);
if (more != 0)
{
  //has more parts
}

另外,请查看专为发送和接收ZeroMQ多部分消息而设计的ZmqMessage C++ library.

点赞