越过电线。

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

消息帧 - gob 文档给人的印象是您可以简单地将 TCP 连接包装在 gob 解码器中并阅读。但是如果你只收到一半的消息会发生什么?gob 能否以某种方式处理这个问题,还是我被迫添加一个消息帧并将消息数据复制到缓冲区中以便 gob 进行反序列化?

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


慕无忌1623718
浏览 228回答 1
1回答

慕森卡

gob 文档给人的印象是您可以简单地将 TCP 连接包装在 gob 解码器中并阅读。正确的。该包旨在在编码器和解码器之间传输多个值。但是如果你只收到一半的消息会发生什么?解码器调用底层 io.Reader 来获取数据。如果 reader 无法返回数据,则 reader 将返回错误。解码器将此错误返回给应用程序。如果 io.Reader 返回错误,则无法恢复解码流。不同类型的消息您可以对成对的消息进行编码,其中第一个告诉应用程序在第二个中期望的类型。您还可以按照您的描述创建“主”类型。您看到的开销是每个流产生一次,而不是每个值产生一次。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go