gpt4 book ai didi

越过电线

转载 作者:IT王子 更新时间:2023-10-29 01:39:32 27 4
gpt4 key购买 nike

我正在考虑使用 gob ("encoding/gob") 在网络协议(protocol)中序列化数据,我一直在四处寻找,似乎找不到解决这些问题的方法:

消息框架 - gob 文档给人的印象是您可以简单地将 TCP 连接包装在 gob 解码器中并读取。但是,如果您只收到半条消息会怎样? gob 能否以某种方式处理这个问题,或者我是否被迫添加消息帧并将消息数据复制到缓冲区中以供 gob 反序列化?

不同类型的消息——协议(protocol)有不同类型的消息,gob 如何最好地处理这个问题?通过在每个 gob blob 之前有一个标识符来指示数据类型?通过将所有消息放入包含所有不同消息字段的“主”消息(将其减少为仅一种类型的消息)?我尝试了后者(更简单),它似乎有巨大的开销(>650 字节)。

最佳答案

The gob documentation gives the impression that you can simply wrap your TCP connection in a gob decoder and read away.

正确。该包旨在在编码器和解码器之间流式传输多个值。

But what happens if you only received half a message?

解码器调用底层的io.Reader获取数据。如果读取器无法返回数据,则读取器将返回错误。解码器将此错误返回给应用程序。

如果 io.Reader 返回错误,则无法恢复解码流。

Different types of messages

您可以对消息对进行编码,其中第一个消息告诉应用程序期望第二个消息的类型。

您还可以按照您的描述创建“主”类型。您看到的开销是每个流产生一次,而不是每个值一次。

关于越过电线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31117999/

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