python Protobuf定义消息类型知识点讲解
让我们从一个非常简单的例子开始。假设您想要定义“搜索请求”的消息格式。每个请求包含一个查询字符串、您对查询结果感兴趣的页数以及每页上有多少个查询结果。
可以采用如下的方式来定义消息类型的.proto文件了:
syntax="proto3";//声明使用proto3语法 messageSearchRequest{ stringquery=1;//每个字段都要指定数据类型 int32page_number=2;//这里的数字2是标识符,最小的标识号可以从1开始,最大到2^29-1,or536,870,911。不可以使用其中的[19000-19999] int32result_per_page=3;//这里是注释,使用// }
(1)第一行指定了你正在使用proto3语法:如果不指定,编译器会使用proto2。这个指定语法必须是文件的非空非注释的第一行。
(2)SearchRequest消息格式有三个字段,在消息中承载的数据分别对应于每一个字段。其中每个字段都有一个名字和一种类型。
(3)向.proto文件添加注释,可以使用C/C++/java风格的双斜杠(//)语法格式。
(4)在消息体中,每个字段都有唯一的一个数字标识符。这些标识符用来在消息的二进制格式中识别各个字段,一旦开始使用就不能再改变。
知识点扩展:
Protobuf不是一个自描述的协议,序列化后的二进制消息中应该没有必要的类型信息。所以采取往消息体中增加额外信息的方式来辅助确定消息类型。
- 使用枚举MsgType定义消息类型,每种消息对应一种消息类型
- 所有的消息都有一个消息类型字段,注意此字段的编号保持确定
- 定义辅助消息BaseMsg,只包含一个消息类型字段,用于辅助反序列化
到此这篇关于pythonProtobuf定义消息类型知识点讲解的文章就介绍到这了,更多相关pythonProtobuf定义消息类型内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。