官方文档:https://developers.google.cn/protocol-buffers
首先让我们看一个非常简单的例子。假设你要定义一个分页搜索请求消息格式,其中每个搜索请求都有一个查询字符串、你感兴趣的特定结果页面以及每页的多个结果。这是.proto你用来定义消息类型的文件。
syntax = "proto3";
message SearchRequest{
string query = 1;
int32 page_number = 2;
int32 result_per_page = 3;
}
文件的第一行指定使用的是proto3语法:如果不这样做,Protocol Buffers编译器将假定你使用的是proto2。这必须是文件的第一个非空、非注释行。
SearchRequest消息定义指定了三个字段(名称/值对),每一个字段用于你希望包含在此类消息中的每条数据。每个字段都有一个名称和一个类型。
在一开始的例子中,所有字段都是标量类型:两个整数(page_number和result_per_page)和一个字符串(query)。但是你也可以为字段指定复合类型,包括枚举和其他消息类型。
消息定义中的每个字段都有一个唯一的编号(如一开始例子中的1、2、3)。这些字段编号用于在消息二进制格式中标识您的字段,并且在使用您的消息类型后不应更改。
请注意:
- 1 到 15 范围内的字段编号需要一个字节进行编码,包括字段编号和字段类型(您可以在Protocol Buffer Encoding中找到更多相关信息)。
- 16 到 2047 范围内的字段编号占用两个字节。
- 因此,您应该为非常频繁出现的消息元素保留数字 1 到 15。
- 请记住为将来可能添加的频繁出现的元素留出一些空间。
您可以指定的最小字段编号是 1,最大的是 2^29 - 1,即 536,870,911。您也不能使用数字 19000 到 19999 (
FieldDescriptor::kFirstReservedNumber到FieldDescriptor::kLastReservedNumber),因为它们是为 Protocol Buffers 实现保留的——如果您在.proto. 同样,您不能使用任何以前保留的字段编号。