grotobuf的proto3 vs proto2

概括:proto3比proto2支持的语言更多,语法更简洁。去掉了复杂的语法和特性,更强调约定而弱化语法。

1.在第一回非空白非注释行,写明语法:

syntax = "proto3";

2.字段规则移除了"required",所有非repeated的字段都默认为optional(可选的)

   在proto2中required也是不推荐使用的。proto3直接从语法层面移除了required规则。

3.“repeated”字段默认采用packed编码

在proto2中,需要明确使用packed=true来为字段指定比较紧凑的packed编码方式。

4.语言增加go,ruby,JavaNano支持

5.移除了default选项

在proto2中,可以使用default选项为某一字段指定默认值。在proto3中,字段的默认值只能根据字段类型由系统决定。默认值全部是约定的,而不再提供默认值的语法。

在字段被设置为默认值的时候,该字段不会被序列化,这样可以节省空间,提高效率。

6.枚举类型的第一个字段必须为0.

7.移除了对分组的支持。分组的功能完全可以使用消息嵌套方式实现。

8.旧代码在解析新增字段时,会把不认识的字段丢弃,再序列化后新增的字段就没了。

在proto2中,旧代码虽然会忽视不认识的新增字段,但并不会丢弃,再序列化的时候那些字段被原样保留。

9.移除了对扩展的支持,新增了Any类型。

10.新增了json映射特性。

猜你喜欢

转载自blog.csdn.net/u010918487/article/details/81255431