1、说明

示例中的proto文件描述了一个数据结构,遵循 Protobuf 语法

示例:

message TestOne {
required string name = 1;
optional int32 age = 2;
}

2、字段类型

type C++ type Java Type Python Type description
double double double float
float float float float
int32 int int int
uint32 uint32 int int/long
int64 int64 long int/long
uint64 uint64 long int/long
sint32 int32 int int 存数据时引入zigzag编码
(Zigzag(n) = (n << 1) ^ (n >> 31)
解决负数太占空间的问题
正负数最多占用5个字节,内存高效
sint64 int64 long int/long
fixed32 uint32 int int/long 4 byte
抛弃了可变长存储策略
适用与存储数值较大数据
fixed64 uint64 long int/long
sfixed32 int32 int int
sfixed64 int64 long int/long
bool bool boolean bool
string string String unicode
bytes string ByteString bytes
  1. 负数使用 sint
  2. 数值较大,使用 fixed

3、字段规则

示例中的 required 和 optional 都是字段规则,规则有以下几个:

字段规则 说明
required 格式良好的 message 必须包含该字段一次
optional 格式良好的 message 可以包含该字段零次或一次(不超过一次)
repeated 该字段可以在格式良好的消息中重复任意多次(包括零)
其中重复值的顺序会被保留。

optional 字段是可选字段,如果不设定数据,则需要有一个默认值以避免出错,指定方式:

message TestOne {
required string name = 1;
optional int32 age = 2 [default = 100];
}

4、字段编号

如示例中,每个字段都有一个编号,这些编号是 唯一的

  • 编号1-15会占用一个字节,16-2047占用两个字节,因此尽可能使用1-15;

  • 字段编号在 message 被使用后,就不能再更改;

5、注释

支持使用 C/C++ 风格的注释

6、类型

6.1、message

  • message 表示一个类型,后面的名称将会是类名;
  • 一个proto文件可以定义多种 message 类型,但尽可能减少一个proto多类型的情况;

组合 messages 会导致膨胀虽然可以在单个 .proto 文件中定义多种 messages 类型(例如 message,enum 和 service),但是当在单个文件中定义了大量具有不同依赖关系的 messages 时,它也会导致依赖性膨胀。建议每个 .proto 文件包含尽可能少的 message 类型。

6.2、service

一般在和RPC系统一起使用,示例:

service TestService {
rpc Test (TestRequest) returns (TestResponse);
}

7、枚举enum

枚举定在 message 内部

示例:

message TestOne {
required string name = 1;
optional int32 age = 2 [default = 100]; enum Country {
China = 0;
USA = 1;
}
optional Country country = 3 [default = China]
}

8、保留字段

示例:

下面例子,字段编号2/15/9/11曾经使用过,保留;字段名 foo/bar 曾经使用过,保留

message Foo {
reserved 2, 15, 9 to 11;
reserved "foo", "bar";
}

如果一个字段不再需要,如果删除或者注释掉,则其他人在修改时会再次使用这些字段编号,那么旧的引用程序就可能出现一些错误,所以使用保留字段,保留已弃用的字段编号或字段名 ,可解决该问题

9、import

如果一个 proto 文件需要使用另一个 proto 文件中的定义(message/service),就需要使用 import 引入其他的 proto 文件

import 使用 public 属性,控制依赖是否可以传递,被 public 修饰的可以传递

示例:

//second.proto
import "message/aaa.proto";
import public "message/bbb.proto";
//test_one.proto
import "message/second.proto"; message TestOne {
required string name = 1;
optional int32 age = 2 [default = 100];
}

如上示例中,test_one.proto 中可以使用 bbb.proto 的类型,但不能使用 aaa.proto 中的类型

9.1、protoc指令

protoc 的参数 -I--proto_path 用于传递 import 的路径

当不同的 proto 文件位于不同的路径时,import 可以不传递相对路径,而使用 -I 或者 --proto_path 传递 import 的查找路径

Protobuf之proto基础语法的更多相关文章

  1. proto 3 语法

    一.简介 proto3是新版本的protobuf语法.它简化了部分语法,并扩大了支持的语言,Ruby.C#.目前谷歌推荐只在是用新支持的语言或使用新的gRPC框架的时候使用.proto2和proto3 ...

  2. proto 2 语法

    一.proto文件 PB的定义是通过proto文件进行定义的,一个标准的类型如下: message SearchRequest { required string query = 1; optiona ...

  3. iOS 集成Protobuf,转换proto文件

    原文地址:http://blog.csdn.net/hyq4412/article/details/54891038 附加Homebrew安装地址:https://brew.sh/index_zh-c ...

  4. [Go] 环境变量,模块化与基础语法

    [环境变量] 安装完 go 之后,设置必要环境变量: export GOPATH=/home/wc/go-lab export GO111MODULE=on export GOPROXY=https: ...

  5. Swift与C#的基础语法比较

    背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...

  6. iOS-----正则表达式的基础语法

    正则表达式简单语法总结 一.什么是正则表达式 从概念上来说,正则表达式也是一门小巧而精炼的语言,它可以用来简化检索特定的字符串,替换特定字符等功能,有许多开发语言工具,都内嵌支持正则表达式.那么一个正 ...

  7. python之最强王者(2)——python基础语法

    背景介绍:由于本人一直做java开发,也是从txt开始写hello,world,使用javac命令编译,一直到使用myeclipse,其中的道理和辛酸都懂(请容许我擦干眼角的泪水),所以对于pytho ...

  8. emmet 系列(1)基础语法

    emmet 系列(1)基础语法 emmet 是一个能显著提升开发html和css开发效率的web开发者工具 emmet基本上目前已知的编辑器都有相应的插件,各个编辑器的emmet插件的下载地址:点我下 ...

  9. Scala基础语法 (一)

    如果你之前是一名 Java 程序员,并了解 Java 语言的基础知识,那么你能很快学会 Scala 的基础语法. Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的. 我 ...

  10. Java基础语法

    java基础学习总结——基础语法1 一.标识符

随机推荐

  1. vue 状态管理 三、Mutations和Getters用法

    系列导航 vue 状态管理 一.状态管理概念和基本结构 vue 状态管理 二.状态管理的基本使用 vue 状态管理 三.Mutations和Getters用法 vue 状态管理 四.Action用法 ...

  2. mysql备份恢复总结

    mysqldump备份注:例子中的语句都是在mysql5.6下执行------------------基础------------------------一.修改my.cnf文件 vi /etc/my ...

  3. 大数据(3)---HDFS客户端命令及java连接

    一.参数设置 之前有说到HDFS的备份数量和切块大小都是可以配置的,默认是备份3,切块大小默认128M 文件的切块大小和存储的副本数量,都是由客户端决定! 所谓的由客户端决定,是通过客户端机器上面的配 ...

  4. C# 排序算法1: 冒泡排序

    本文用控制台程序展示数据排序前后的变化,本文数据都按将从小到大进行排序. 1.  准备arr数据  及 arr数据的展示 /// <summary> /// 生成n个元素的int数组 // ...

  5. Go socket 编程源码解析(上)

    0. socket 介绍 Liunx 中一切皆文件.通过文件描述符和系统调用号可以实现对任何设备的访问.同样的,socket 也是一种文件描述符.通过 socket 可以建立网络传输.对于 TCP 和 ...

  6. linux 服务器运行jmeter 进行服务性能压测

    本文为博主原创,转载请注明出处: 起初需要了解项目服务的性能和瓶颈,就想要用 jmeter 进行压测,刚开始都是启动本地的jmeter 压测服务器上项目服务的性能,发现服务器的 cpu 和内存等一直升 ...

  7. linux route 命令

    route 管理路由表         要实现两个不同的子网之间的通信,需要一台连接两个网络的路由器,或者同时位于两个网络的网关来实现.在Linux系统中,设置路由通常是为了解决以下问题:该Linux ...

  8. 【ArgParse】一个开源的入参解析库

    项目地址:argtable3 本地验证: 编译构建 新增验证 // examples/skull.c #include "argtable3.h" int main(int arg ...

  9. CPU信息查看的工具

    CPU信息查看的工具 背景 信创国产化如火如荼. CPU的型号其实越来越多 lscpu出来的结果其实太抽象, 对CPU的缓存架构显示不充分 今天在看大佬的文章是看到了一个工具: hwloc 感觉非常优 ...

  10. [转帖]Linux ps -o 查看进程启动时间

    https://www.cnblogs.com/apink/p/17572435.html 时间参数 如下表 参数  含义 start 显示进程启动时间的简短格式.通常,它会显示日期时间中的月-日 或 ...