在一个协议缓冲区二进制文件中存储多个消息

问题描述

这是协议缓冲区文档的“技术”部分对重复消息的说明:

如果要将多个消息写入单个文件或流,则由您来跟踪一条消息的结尾和下一条消息的开始。协议缓冲区连线格式不是自定界的,因此协议缓冲区解析器无法确定消息在何处结束。解决此问题的最简单方法是在编写消息本身之前先编写每个消息的大小。当您读回消息时,您将读取大小,然后将字节读取到一个单独的缓冲区中,然后从该缓冲区进行解析。(如果要避免将字节复制到单独的缓冲区,请签出CodedInputStream类(在C ++和Java中),可以告知该类将读取限制为一定数量的字节。)

解决方法

我有重复的消息,我想存储在一个文件中。目前,我必须将此重复消息包装在另一条消息中。有没有解决的办法?

package foo;

message Box {
  required int32 tl_x = 1;
  required int32 tl_y = 2;
  required int32 w = 3;
  required int32 h = 4;
}

message Boxes {
  repeated Box boxes = 1;
}