gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-28 06:42:46 26 4
gpt4 key购买 nike

我正在开发一个使用 cppZmq 绑定(bind)的 native 应用程序。我的消息传递代理从 ZMQ_ROUTER 读取消息,并在应用一些负载平衡逻辑后将它们转发到另一个 ZMQ_ROUTER。我使用 message_t 类来接收数据(它在内部只调用 zmq_recv 和 zmq_msg_t 结构)。

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

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

最佳答案

我的强烈建议是在尝试优化之前先找到一个可行的解决方案。现在,内存分配器非常高效;当您开始分析您的应用程序时,内存分配可能甚至不会注册。但是,如果内存优化是可取的,您将能够发布一些工作代码,这样评论起来会容易得多。 [很难从代码的文本描述中形象化代码。]

关于c++ - ZeroMQ 使用相同的 zmq_msg_t 接收多条消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25636770/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com