protobuf

打印 上一主题 下一主题

主题 863|帖子 863|积分 2589

模板
  1. syntax = "proto3"; // 指定 protobuf 的版本  
  2.   
  3. package example; // 定义包名  
  4.   
  5. // 导入其他 protobuf 文件  
  6. import "google/protobuf/timestamp.proto";  
  7. import "other_package/other_file.proto";  
  8.   
  9. // 定义一个枚举类型  
  10. enum State {  
  11.  UNKNOWN = 0; // 枚举值必须从 0 开始  
  12.  STARTED = 1;  
  13.  RUNNING = 2;  
  14.  STOPPED = 3;  
  15. }  
  16.   
  17. // 定义一个消息类型  
  18. message Person {  
  19.  // 定义一个字符串字段  
  20.  string name = 1; // 字段编号必须是唯一的正整数  
  21.   
  22.  // 定义一个整型字段  
  23.  int32 id = 2; // 这里的 2 是字段编号  
  24.   
  25.  // 定义一个布尔字段  
  26.  bool has_pony = 3;  
  27.   
  28.  // 定义一个浮点字段  
  29.  float salary = 4;  
  30.   
  31.  // 定义一个枚举字段  
  32.  State state = 5;  
  33.   
  34.  // 定义一个重复字段(类似于列表)  
  35.  repeated string emails = 6;  
  36.   
  37.  // 定义一个嵌套消息  
  38.  message Address {  
  39.    string line1 = 1;  
  40.    string line2 = 2;  
  41.    string city = 3;  
  42.    string country = 4;  
  43.    string postal_code = 5;  
  44.  }  
  45.   
  46.  // 定义一个嵌套消息字段  
  47.  Address address = 7;  
  48.   
  49.  // 定义一个 map 字段(类似于字典)  
  50.  map<string, string> phone_numbers = 8;  
  51.   
  52.  // 定义一个任意类型字段  
  53.  google.protobuf.Any any_field = 9;  
  54.   
  55.  // 定义一个时间戳字段  
  56.  google.protobuf.Timestamp last_updated = 10;  
  57.   
  58.  // 定义一个从其他文件导入的消息类型字段  
  59.  other_package.OtherMessage other_field = 11;  
  60.   
  61.  // 定义一个 oneof 字段,可以设置其中一个字段  
  62.  oneof test_oneof {  
  63.    string name = 12;  
  64.    int32 id = 13;  
  65.    bool is_test = 14;  
  66.  }  
  67. }  
  68.   
  69. // 定义一个服务  
  70. service ExampleService {  
  71.  // 定义一个 RPC 方法,请求类型为 GetPersonRequest 响应类型为 Person  
  72.  rpc GetPerson(GetPersonRequest) returns (Person);  
  73. }  
  74.   
  75. // 定义 GetPerson RPC 方法的请求消息类型  
  76. message GetPersonRequest {  
  77.  int32 person_id = 1;  
  78. }
复制代码
特殊注意


  • 字段编号一旦被分配后就不应更改,为了保持向后兼容性
  • 编号在 [1,15] 范围内的字段编号在序列化时只占用一个字节。因此,为了优化性能,对于频仍使用的字段,尽可能使用该范围内的数字。同时也要为未来可能添加的常用字段预留一些编号(不要一股脑把 15 之内的编号都用了!)
  • 字段号 19000,19999 是为 Protocol Buffers 实现保留的。
  • 保留字段:如果你通过完全删除字段或将其解释来更新消息类型,则未来其他开发者对类型进行自己的更新时就有可能重用字段编号。当旧版本的代码遇到新版本生成的消息时,由于字段编号的重新分配,可能会引发解析错误或不预期的行为。为了避免这种潜在的兼容性问题,protobuf 提供 reserved 关键字来明确标记不再使用的字段编号或标识符,如果将来的开发者实验使用这些标识符,proto 编译器将会报错提醒。
  1. message Foo {
  2.   reserved 2, 15, 9 to 11, 40 to max;
  3.   // 9 to 11 表示区间 [9,11], 40 to max 表示区间 [40, 编号的最大值]
  4.   reserved "foo", "bar";
  5. }
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

小秦哥

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表