先介绍几个常用关键字:

equired前缀表示该字段为必要字段,既在序列化和反序列化之前该字段必须已经被赋值。与此同时,在Protocol Buffer中还存在另外两个类似的关键字,optional和repeated,带有这两种限定符的消息字段则没有required字段这样的限制。相比于optional,repeated主要用于表示数组字段

标签数字123则表示不同的字段在序列化后的二进制数据中的布局位置

对于Protocol Buffer而言,标签值为1到15的字段在编码时可以得到优化,即标签值和类型信息仅占有一个byte,标签范围是16到2047的将占有两个bytes,而Protocol Buffer可以支持的字段数量则为2的29次方减一。有鉴于此,我们在设计消息结构时,可以尽可能考虑让repeated类型的字段标签位于1到15之间,这样便可以有效的节省编码后的字节数量

Extentions

extensions 声明一个消息中的一定范围的field的顺序数字用于进行扩展。其它人可以在自己的.proto文件中重新定义这些消息field,而不需要去修改原始的.proto文件

message Foo {

// .....

extensions 100 to 199;

}

这些说明100-199的field是保留的。其它用户可以用这些field在他们自己的.proto文件中添加新的fields给Foo。举例:

extend Foo {

optional int32 bar = 126;

}

非常重要的一点是双方不能使用同样数字添加一样的message类型,这样extension会被解释为错误类型。

可能需要有一个关于field的数字顺序的约定来保证你的project不会发生这样的重复的问题。

如果你的field数字比较大的话,可以使用max来指定你的textension范围上升到最大的范围

message Foo {

extensions 1000 to max;

}

没有指定默认值的话,string 默认为空串,bool 默认为false,数字类型默认0,枚举类型,默认为类型定义中的第一个值

1. proto文件基础写法

syntax = "proto3"; //syntax = “proto3”:表示这是使用protobuf3的语法,不加这句默认使用protobuf2的语言

message Person { // message类似class
string name = 1; // 1 表示这个字段存储的位置
int32 id = 2; // 字段格式:限定符① | 数据类型② | 字段名称③ | = | 字段编码值④ | [字段默认值⑤]
string email = 3;
bytes image = 4; // 定义nsndata
bool isHave = 5;
map<string, string> projects = 6; // 定义字典
repeated string array = 7; // 定义数组
float numFool = 8;
double numDouble = 9;

}
// 限定符: singular,repeated
//singular:一个正确定义的消息包含零或者1个该field.不超过1个
//repeated:可以添加多个,相当于一个数组.排列顺序就是添加时的顺序.protobuf3对scalar数字类型的repeated限定默认都是packed的,这样可以节省很多空间,共用一个key,减少了key的占用.

// 在当前目录便可以看到Test.pbobjc.h和Test.pbobjc.m这两个文件了(需要注意的是生成的代码是MRC的,如果引入ARC工程中记得添加-fno-objc-arc的标签).

2.

syntax = "proto3"; //syntax = “proto3”:表示这是使用protobuf3的语法,不加这句默认使用protobuf2的语言

message Person {
string name = 1;
int32 id = 2;
PhoneNumber pp = 3; // // 可以嵌套
PhoneType type = 5; // 可以使用枚举
repeated PhoneNumber phone = 4; //
}

message PhoneNumber {
string number = 1;
PhoneType type = 2 ;
}

enum PhoneType {
//enum类型必须有一个明确是0的字段,这个一是为了和protobuf2兼容,而是使其有个默认值
MOBILE = 0;
HOME = 1;
WORK = 2;
}

3.

syntax = "proto3"; //syntax = “proto3”:表示这是使用protobuf3的语法,不加这句默认使用protobuf2的语言

import "google/protobuf/any.proto";

message Person {
string name = 1;
int32 id = 2;
string email = 3;
repeated google.protobuf.Any details = 5; // any任何类型

}

enum EnumAllowingAlias {
option allow_alias = true; // 如果想让不同的枚举指向同一个field
UNKNOWN = 0;
STARTED = 1;
RUNNING = 1;
}

最新文章

  1. 从零开始学 Java - Spring 集成 Memcached 缓存配置(二)
  2. Django配置和初探
  3. DevExpress的GridControl的实时加载数据解决方案(取代分页)
  4. [转]zetex.lib
  5. 查看linux [Fedora] 系统信息
  6. Java8新特性之一、时间日期API
  7. ..在lua中运用
  8. Jersey搭建Restful服务器 on Ubuntu
  9. TabControl选项卡
  10. Haproxy小酌
  11. Judy Beta Postmortem
  12. MAC上截图,编辑图片与恢复图片
  13. C# 绘图时使用抗锯齿会多出一个像素
  14. centos 6.8下载地址
  15. H5学习的例子
  16. b3_trcd_EDCD_new
  17. 用Python实现的数据结构与算法:基本搜索
  18. Linux CentOS6环境下MySQL5.1升级至MySQL5.5版本过程
  19. 匿名类型与Select方法实现自定义对象插入局部表结构中
  20. JNI之——在cmd命令行下编译执行C/C++源文件

热门文章

  1. Sass学习笔记
  2. 小公司0成本基于Pythony的单元\GUI\Web自动化\性能的几个开源软件测试工具
  3. .net 项目生成时自动更新版本号
  4. Beta版本冲刺第二天
  5. Frameset框架
  6. 常用的Jquery插件
  7. windows多线程编程实现 简单(1)
  8. qrcode 生成验证码带文字
  9. JS 工具类
  10. 保留password模式文本框textbox内的数据不丢失。