Protobuf之proto基础语法
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 |
- 负数使用 sint ;
- 数值较大,使用 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基础语法的更多相关文章
- proto 3 语法
一.简介 proto3是新版本的protobuf语法.它简化了部分语法,并扩大了支持的语言,Ruby.C#.目前谷歌推荐只在是用新支持的语言或使用新的gRPC框架的时候使用.proto2和proto3 ...
- proto 2 语法
一.proto文件 PB的定义是通过proto文件进行定义的,一个标准的类型如下: message SearchRequest { required string query = 1; optiona ...
- iOS 集成Protobuf,转换proto文件
原文地址:http://blog.csdn.net/hyq4412/article/details/54891038 附加Homebrew安装地址:https://brew.sh/index_zh-c ...
- [Go] 环境变量,模块化与基础语法
[环境变量] 安装完 go 之后,设置必要环境变量: export GOPATH=/home/wc/go-lab export GO111MODULE=on export GOPROXY=https: ...
- Swift与C#的基础语法比较
背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...
- iOS-----正则表达式的基础语法
正则表达式简单语法总结 一.什么是正则表达式 从概念上来说,正则表达式也是一门小巧而精炼的语言,它可以用来简化检索特定的字符串,替换特定字符等功能,有许多开发语言工具,都内嵌支持正则表达式.那么一个正 ...
- python之最强王者(2)——python基础语法
背景介绍:由于本人一直做java开发,也是从txt开始写hello,world,使用javac命令编译,一直到使用myeclipse,其中的道理和辛酸都懂(请容许我擦干眼角的泪水),所以对于pytho ...
- emmet 系列(1)基础语法
emmet 系列(1)基础语法 emmet 是一个能显著提升开发html和css开发效率的web开发者工具 emmet基本上目前已知的编辑器都有相应的插件,各个编辑器的emmet插件的下载地址:点我下 ...
- Scala基础语法 (一)
如果你之前是一名 Java 程序员,并了解 Java 语言的基础知识,那么你能很快学会 Scala 的基础语法. Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的. 我 ...
- Java基础语法
java基础学习总结——基础语法1 一.标识符
随机推荐
- go语言-Go环境搭建
go语言-Go环境搭建 下载 https://golang.org/dl/ 切换root权限 su root 进入用户列表 cd /usr/local/ 解压缩 tar -zxvf go1.13.li ...
- idea创建父子项目
1. 首先创建大的project 父工程: 2. 点击下一步之后: 3. 点击下一步,填写项目存放地址,点击finish: 4. 完成之后删除不需要的文件,保留pom文件,检查对应的jar和spri ...
- SCA 技术进阶系列(二):代码同源检测技术在供应链安全治理中的应用
直击痛点:为什么需要同源检测 随着 "数字中国" 建设的不断提速,企业在数字化转型的创新实践中不断加大对开源技术的应用,引入开源组件完成应用需求开发已经成为了大多数研发工程师开发软 ...
- 1 Englishi 词根
1 ab 离去,相反, 不 (负能量的) abnormal abuse 2 anti 反对,相反 antiwar antiaging antiforeign antinoise 3 co-/col ...
- 微信小程序从基础入门到项目实战-黑马程序员-pink老师推荐(持续更新)
https://www.bilibili.com/video/BV1WJ41197sD/?spm_id_from=333.788.recommend_more_video.0
- IDE暗黑主题推荐-Dracula
作为程序员,我们一天中会花费大量时间在编码和阅读代码上.优秀的代码编辑器主题可以减轻眼睛的疲劳,提高工作效率.本文向大家推荐一款非常流行的 JetBrains IDE 主题插件 - Dracula.它 ...
- freeswitch xml_rpc模块
概述 freeswitch有非常多的周边模块,给我们提供各种各样的功能,有些功能在适当的场景下可以极大的方便我们的开发和应用. 今天我们介绍一个不常用的模块mod_xml_rpc. freeswitc ...
- SV 接口中的clocking
接口 module可以例化模块,可以例化接口 接口不能例化模块 采样和数据驱动 时钟驱动数据,数据会有延迟,RTL仿真的时候,不会仿真出这个延时;RTL仿真的时候,不会仿真出寄存器的延时;只有在门级仿 ...
- Mygin 实现简单Http
本篇是完全参考gin的功能,自己手动实现一个类似的功能,帮助自己理解和学习gin框架 目的 简单介绍net/http库以及http.Handler接口 实现简单的功能 标准库启动Web服务 impor ...
- [转帖]jvm学习三-MAT内存分析工具的使用
目录 1 模拟内存溢出程序 1.1 jvm配置 1.2 测试代码 2 MAT工具进行内存分析 2.1 大纲介绍 2.2 Histogram视图介绍 2.3 Leak Suspects视图介绍 2.4 ...