• 技术文章 >Python技术 >Python基础教程

    python Protobuf定义消息类型

    小妮浅浅小妮浅浅2021-04-27 10:01:37原创2517

    本文教程操作环境:windows7系统、Python 3.9.1,DELL G3电脑。

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

    可以采用如下的方式来定义消息类型的.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)在消息体中,每个字段都有唯一的一个数字标识符。这些标识符用来在消息的二进制格式中识别各个字段,一旦开始使用就不能再改变。

    以上就是python Protobuf定义消息类型,希望能对大家有所帮助。更多Python学习指路:python基础教程

    专题推荐:python protobuf
    上一篇:python中gRPC是什么? 下一篇:python中Protobuf创建服务端代码

    相关文章推荐

    • python构造函数是什么?• python中Allure框架是什么?• python中Pexpect的工作流程• Python运行程序的三种方法• python plot()函数的基本介绍• python抽象类的知识整理• python模块的搜索路径如何理解?• python包的导入方式有几种• python中gRPC是什么?

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网