谷歌最近发布了v3版本的protobuf,以前的protobuf被称之为v2,二者之间的区别其特点见我上一篇blog《protobuf一些注意事项》。
个人以为v3要比v2好处就在于:简洁,且二者的新版本都共同支持了新的数据类型:map。相比v2,它去掉了required等选项,只保留了repeated选项,还添加了时间等比较常用的数据类型(当然暂时还没有实现)等等。唯一的缺点就是,v3还没有发布beta版,目前的版本是protobuf-3.0.0-alpha-1。
为了测试v3对v2的兼容性,我写了一个程序,v2的协议内容如下:
- syntax = "proto2";
-
- package proto3_proto;
-
- message Message
- {
- enum Humour {
- UNKNOWN = 0;
- PUNS = 1;
- SLAPSTICK = 2;
- BILL_BAILEY = 3;
- }
-
- optional string name = 1;
- optional Humour hilarity = 2;
- optional uint32 height_in_cm = 3;
- optional bytes data = 4;
- optional int64 result_count = 7;
- optional bool true_scotsman = 8;
- optional float score = 9;
-
- repeated uint64 key = 5 [packed = true];
- // repeated uint64 key = 5;
- }
-
- message MessageArray
- {
- map<string, Message> msg_map = 1;
- }
上面的协议内容基本上把protobuf各种数据类型都包括了,下面是对应的v3版本协议:
- syntax = "proto3";
-
- package proto3_proto;
-
- message Message
- {
- enum Humour {
- UNKNOWN = 0;
- PUNS = 1;
- SLAPSTICK = 2;
- BILL_BAILEY = 3;
- }
-
- string name = 1;
- Humour hilarity = 2;
- uint32 height_in_cm = 3;
- bytes data = 4;
- int64 result_count = 7;
- bool true_scotsman = 8;
- float score = 9;
-
- repeated uint64 key = 5[packed = true];
- }
-
- message MessageArray
- {
- map<string, Message> msg_map = 1;
- }
v3的协议内容看着比v2清爽一些。 写了一个测试程序,其内容就不列出来了,我放在了
百度网盘
,感兴趣的自己去下载。只要是v3没有改变v2的部分,二者编码后的内容是一致的。
待v3的stable版本发布出来时候,它可能就开始支持时间等一些常用类型了,据说还可以把内容序列化为json格式,到时候再把更新本篇的内容。