当前位置: 首页 > article >正文

proto语法说明

官方文档:https://developers.google.cn/protocol-buffers/docs/proto3

一、基本语法示例

/*头部相关声明
*/
syntax = "proto3"; // 语法版本为protobuf3.0
package = "com.xxx.foo"; // 定义包名
import "common.proto"; // 导入common.proto
option java_package = "com.xxx.foo"; // 指定java包// 搜索请求
message SearchRequest{int32 page = 1; // 当前页int32 page_size = 2; // 一页多少条,使用下划线分隔,设置的时候使用驼峰命令法,如:setPageSize(10);enum Type {IN = 0; // 0需要是第一个,第一个也是默认值OUT = 1;}Type type = 3; // 类型
}// 搜索响应
message SearchResponse{int32 code = 1; // 状态码string message = 2; // 消息SearchList data = 3; // 数据,类型为SearchList
}// SearchList结构
message SearchList{repeated Item data = 1; // 数据记录项,repeated类型用来存放N个相同类型的内容int64 count = 2; // 总条数int32 page_size = 3; // 一页条数
}// Item结构
message Item{int64 id = 1; // idstring title = 2; // 标题int64 create_time = 3; // 创建时间int64 update_time = 4; // 更新时间
}// 服务
service SearchService{rpc GetSearchList(SearchRequest) returns (SearchResponse); // rpc 方法
}

命令规范建议使用上面示例

字段类型有:

二、字段修饰符

  • singular:单个的,有0个或1个(默认)
  • repeated:重复的,重复任意次数
  • required:要求的
  • optional:可选的
  • reserved:保留的,保留字段名或字段号
message Foo {reserved 2, 15, 9 to 11;reserved "foo", "bar";string foo = 3 // 编译报错,因为‘foo’已经被标为保留字段
}

[warning] 注意:不能在同一个reserved语句中同时使用字段名和字段号。

三、嵌套

message SearchResponse {message Result {string id = 1;string title = 2;}repeated Result results = 1;
}

四、引用

message OtherMessage {SearchResponse.Result result = 1;
}

五、使用Any类型

需要导入import google/protobuf/any.proto

import "google/protobuf/any.proto";message ErrorStatus {string message = 1;repeated google.protobuf.Any details = 2;
}

六、oneof

oneof除了共享内存中的所有字段外,oneof字段与常规字段类似,并且最多可以同时设置一个字段。

message TestMessage {oneof test_oneof {int32 id = 1;string title = 2;}
}

七、系统默认值

  • string默认为空字符串
  • bool默认为false
  • 数值默认为0
  • enum默认为第一个元素

欢迎关注:https://fenxianglu.cn/

参考链接:

  • https://blog.csdn.net/baidu_32237719/article/details/99854208
  • https://www.jianshu.com/p/6a6dbff2b5cd
http://www.lryc.cn/news/2415517.html

相关文章:

  • 最新短视频去水印解析API接口分享
  • 三星 原生android,原生Android 4.0 三星GALAXY Nexus评测
  • java技术讨论QQ群号码:40820473
  • 无人机倾斜摄影测量技术,倾斜摄影三维建模测量技术及其应用详解
  • 数字图像基本知识
  • 全网最新最详细【2024版本】Kali Linux 渗透测试技术大全
  • python爬取网页数据步骤,python爬取网页详细教程
  • 冰峰王座完整的语音英文+中文解释!(修订版)
  • Microsoft live labs Pivot 和Google wave邀请
  • RTTSTM32开发实践1:开发环境搭建
  • Win11 预览体验计划空白无显示的一种解决方案
  • 【网页设计与制作成品】 web前端开发技术 web课程设计 网页规划与设计
  • 启动应用程序出现d3dx9_27.dll缺少问题解决
  • 最新华为鸿蒙系统升级名单,鸿蒙系统首批升级机型名单_华为鸿蒙系统升级机型名单时间表...
  • 口令
  • 好用的影子系统软件,系统辅助工具
  • ES优化实战 - 小操作节省百分之三十以上的磁盘空间
  • 计算机网络模型及协议简介
  • 用计算机唱歌弹奏china,新目标英语专题练习:句型转换(附答案)
  • identity_insert 如何改为on_如何找到模型中你想要找的所有元素
  • 无线网络监控服务器怎么,无线监控系统如何安装?
  • 为博客添加音乐播放器并保持跳转时不中断播放状态
  • ddddy
  • 斯隆奖新晋得主宋舒然:从视觉出发,打造机器人之「眼」
  • XP SP3 IIS 5.1版本安装包下载地址和XP SP3 IIS 5.1版本安装方法
  • Dubbo 负载均衡
  • HTML制作个人网页制作(简单静态HTML个人博客网页作品)
  • Windows 8 Platform (三) Windows 8 Developer Preview
  • 使用AspectJ来Hook你的Android代码
  • 笔记本键盘清理详解——东芝PR100