python Protobuf定义消息类型知识点讲解


Posted in Python onMarch 02, 2021

让我们从一个非常简单的例子开始。假设您想要定义“搜索请求”的消息格式。每个请求包含一个查询字符串、您对查询结果感兴趣的页数以及每页上有多少个查询结果。

可以采用如下的方式来定义消息类型的.proto文件了:

syntax = "proto3"; // 声明使用 proto3 语法
message SearchRequest {
string query = 1; // 每个字段都要指定数据类型
int32 page_number = 2; // 这里的数字2 是标识符,最小的标识号可以从1开始,最大到2^29 - 1, or 536,870,911。不可以使用其中的[19000-19999]
int32 result_per_page = 3; // 这里是注释,使用 //
}

(1)第一行指定了你正在使用 proto3 语法:如果不指定,编译器会使用 proto2。这个指定语法必须是文件的非空非注释的第一行。

(2)SearchRequest消息格式有三个字段,在消息中承载的数据分别对应于每一个字段。其中每个字段都有一个名字和一种类型。

(3)向.proto文件添加注释,可以使用C/C++/java风格的双斜杠(//) 语法格式。

(4)在消息体中,每个字段都有唯一的一个数字标识符。这些标识符用来在消息的二进制格式中识别各个字段,一旦开始使用就不能再改变。

知识点扩展:

Protobuf 不是一个自描述的协议,序列化后的二进制消息中应该没有必要的类型信息。所以采取往消息体中增加额外信息的方式来辅助确定消息类型。

  1. 使用枚举MsgType定义消息类型,每种消息对应一种消息类型
  2. 所有的消息都有一个消息类型字段,注意此字段的编号保持确定
  3. 定义辅助消息BaseMsg,只包含一个消息类型字段,用于辅助反序列化

到此这篇关于python Protobuf定义消息类型知识点讲解的文章就介绍到这了,更多相关python Protobuf定义消息类型内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
在Heroku云平台上部署Python的Django框架的教程
Apr 20 Python
Python中函数的参数定义和可变参数用法实例分析
Jun 04 Python
Python中functools模块的常用函数解析
Jun 30 Python
Python基于identicon库创建类似Github上用的头像功能
Sep 25 Python
Python随机函数random()使用方法小结
Apr 29 Python
pytorch + visdom CNN处理自建图片数据集的方法
Jun 04 Python
浅析Python函数式编程
Oct 06 Python
对python自动生成接口测试的示例讲解
Nov 30 Python
python写程序统计词频的方法
Jul 29 Python
tornado+celery的简单使用详解
Dec 21 Python
python redis存入字典序列化存储教程
Jul 16 Python
python套接字socket通信
Apr 01 Python
Django项目在pycharm新建的步骤方法
Mar 02 #Python
基于注解实现 SpringBoot 接口防刷的方法
Mar 02 #Python
python Autopep8实现按PEP8风格自动排版Python代码
Mar 02 #Python
pycharm配置安装autopep8自动规范代码的实现
Mar 02 #Python
Python实现我的世界小游戏源代码
Mar 02 #Python
VSCode中autopep8无法运行问题解决方案(提示Error: Command failed,usage)
Mar 02 #Python
python 基于pygame实现俄罗斯方块
Mar 02 #Python
You might like
PHP中的integer类型使用分析
2010/07/27 PHP
PHP 第三节 变量介绍
2012/04/28 PHP
本地机apache配置基于域名的虚拟主机详解
2013/08/10 PHP
thinkphp3.2.3 分页代码分享
2016/07/28 PHP
php-fpm添加service服务的例子
2018/04/27 PHP
Laravel 5.5 实现禁用用户注册示例
2019/10/24 PHP
有关于eclipse配置spket需要注意的一些地方
2013/04/07 Javascript
js获取url中的参数且参数为中文时通过js解码
2014/03/19 Javascript
用html5 js实现点击一个按钮达到浏览器全屏效果
2014/05/28 Javascript
jquery获取节点名称
2015/04/26 Javascript
JS实现黑色风格的网页TAB选项卡效果代码
2015/10/09 Javascript
jquery实现鼠标悬浮停止轮播特效
2020/08/20 Javascript
JS获取鼠标坐标位置实例分析
2016/01/20 Javascript
Node.js重新刷新session过期时间的方法
2016/02/04 Javascript
JavaScript易错知识点整理
2016/12/05 Javascript
webpack4.x CommonJS模块化浅析
2018/11/09 Javascript
基于 jQuery 实现键盘事件监听控件
2019/04/04 jQuery
微信小程序云开发之模拟后台增删改查
2019/05/16 Javascript
vue实现条件叠加搜索的解决方法
2019/05/28 Javascript
小谈angular ng deploy的实现
2020/04/07 Javascript
JavaScript oncopy事件用法实例解析
2020/05/13 Javascript
解决ant Design中Select设置initialValue时的大坑
2020/10/29 Javascript
Python修改Excel数据的实例代码
2013/11/01 Python
Python多线程threading和multiprocessing模块实例解析
2018/01/29 Python
Python实现替换文件中指定内容的方法
2018/03/19 Python
通过PYTHON来实现图像分割详解
2019/06/26 Python
详解python实现小波变换的一个简单例子
2019/07/18 Python
通过Python扫描代码关键字并进行预警的实现方法
2020/05/24 Python
Django CBV模型源码运行流程详解
2020/08/17 Python
雅诗兰黛美国官网:Estee Lauder美国
2016/07/21 全球购物
金宝贝童装官网:Gymboree
2016/08/31 全球购物
英国高街奥特莱斯:Highstreet Outlet
2019/11/21 全球购物
勤奋学习演讲稿
2014/05/10 职场文书
综艺节目策划方案
2014/06/13 职场文书
Windows server 2016服务器基本设置
2022/08/14 Servers
React更新渲染原理深入分析
2022/12/24 Javascript