ZeroMQ使用相同的zmq_msg_t接收多条消息

ZeroMQ Use same zmq_msg_t for Receiving Multiple Messages

本文关键字:消息 msg ZeroMQ zmq      更新时间:2023-10-16

我正在开发一个使用cppZmq绑定的本机应用程序。我的消息代理从ZMQ_ROUTER读取消息,并在应用一些负载平衡逻辑后将它们转发给另一个ZMQ_RUTER。我使用一个message_t类来记录数据(它在内部只是用zmq_msg_t结构调用zmq_recv)。

在我的轮询循环中,我可以使用message_t变量(循环外分配的堆栈)来接收消息,转发到套接字,然后在循环的下一次迭代中使用相同的message_t参数来接收另一条消息吗?或者,我应该在轮询循环内部堆栈分配message_t变量吗;换句话说,在使用相同的zmq_msg_t变量执行zmq_recv之前,是否必须先zmq_close一条消息,zmq_msg_init一遍?这可能没有可衡量的性能考虑因素,但目标是把事情做好,以避免以后在开发周期中出现错误。

此外,我是否可以从一个套接字中获取一个zmq_msg_t结构,并将其转发到另一个套接字,而不创建新的消息结构,并对其执行zmq_msg_copy?

我的强烈建议是,在尝试优化之前,先获得一个有效的解决方案。如今,内存分配器非常高效;当您开始评测应用程序时,内存分配可能甚至不会注册。然而,如果内存优化是可取的,你可以发布一些工作代码,这样就更容易评论了。[很难从文本描述中可视化代码。]