分享zframe_send使用过程中 的一个小问题

26 篇文章 0 订阅

zframe_send函数中,第一个参数是一个指向zframe_t指针的指针。这是因为在发送帧之后,该函数会销毁帧并将你的指针设置为NULL。这样做是为了防止你再次使用已经被销毁的帧。

所以,如果你的发送数据后续还要使用,可以使用zframe_dup函数处理这种情况。 你需要创建一个新的zframe_t指针,并将sendData的内容复制到这个新的帧中,然后发送这个新的帧。

这是一个可能的解决方案:

void messageListeningProcessingBranch(zsock_t *sDataSock, const zframe_t &sendData)
{
    zframe_t *frame = zframe_dup(&sendData);  // 创建一个新的帧并复制sendData的内容
    zframe_send(&frame, sDataSock, 0);  // 发送新的帧
}

在这个函数中,zframe_dup函数会创建一个新的zframe_t对象,并将sendData的内容复制到这个新的对象中。然后,zframe_send函数会发送这个新的帧,并在发送之后销毁它。

附赠一些相关函数的介绍。
使用ZeroMQ库中的zframe模块进行消息的接收和发送。下面是相关函数的使用介绍:

  1. zframe_recv(responder): 这个函数用于从指定的套接字(在这里是responder)接收一个帧。如果接收成功,它将返回一个新的zframe_t对象,否则返回NULL。这个函数会阻塞,直到有一个帧可以接收。

  2. zframe_strdup(frame_recv): 这个函数用于复制一个帧的数据并将其作为一个新的字符串返回。这个字符串需要在使用完毕后通过free()函数释放。

  3. zframe_size(frame_recv): 这个函数用于获取一个帧的大小,以字节为单位。

  4. zsys_info("Received: %s", message): 这个函数用于打印信息。在这里,它被用来打印接收到的消息。

  5. zframe_send(&frame_recv, responder, 0): 这个函数用于将一个帧发送到指定的套接字(在这里是responder)。第三个参数是一个标志,用于指定发送的方式。在这里,它被设置为0,表示这个函数在发送帧后不会销毁它。如果发送成功,这个函数将返回0,否则返回-1。

  6. free(message): 这个函数用于释放之前通过zframe_strdup()函数复制的字符串。

以上代码的组合使用的一个实例如下

zframe_t *frame_recv = zframe_recv(responder);//responder 是创建的接收套接字
if (frame_recv)
{
    char *message = zframe_strdup(frame_recv);

    print_hex(message, zframe_size(frame_recv));
    zsys_info("Received: %s", message);

    zframe_send(&frame_recv, responder, 0);  // 直接转发接收到的消息

    free(message);  // 释放复制的字符串
}

分享一个有趣的 学习链接:https://xxetb.xet.tech/s/HY8za

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值