官方文档:https://developers.google.cn/protocol-buffers
文章目录
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
. 同样,您不能使用任何以前保留的字段编号。
指定字段规则
消息字段可以是以下之一:
- 单数:格式良好的消息可以有零个或一个此字段(但不能超过一个)。这是 proto3 语法的默认字段规则。
repeated
:该字段可以在格式良好的消息中重复任意次数(包括零次)。重复值的顺序将被保留。
在 proto3 中,repeated
标量数值类型的字段packed
默认使用编码。
您可以在Protocol Buffer Encoding中找到有关packed
编码的更多信息。
添加更多消息类型
可以在单个.proto
文件中定义多种消息类型。如果您要定义多个相关消息,这很有用——例如,如果您想定义与您的SearchResponse
消息类型相对应的回复消息格式,您可以将其添加到相同的.proto
:
message SearchReques