google protobuf repeated 字段二义性
2011-11-02 18:01
525 查看
protobuf 消息的repeated字段,可以包含0~N个相同的内容。
当包含的内容大于0时,可以认为是在修改数据或者数据有改变。
当包含的内容是0时,也就是不包含时,究竟是不改变原来的数据,还是清空呢?
因此在设计协议时,遇到repeated字段时,最好在与某个optional字段相组合,用来指示是否包含相应的repeated字段。
例如。
message MSG1
{
repeated fixed32 data = 1;
optional bool include_data = 2
}
当 include_data = true 时,表示要修改data字段,此时如果data字段包含0个元素则是清空。
如果include_data = false ,时表示对data字段不做任何改变,此时data字段包含0个元素或者多个元素在业务逻辑上都应该被忽略。
以上方法可以解决了repeated字段的二义性问题。
当包含的内容大于0时,可以认为是在修改数据或者数据有改变。
当包含的内容是0时,也就是不包含时,究竟是不改变原来的数据,还是清空呢?
因此在设计协议时,遇到repeated字段时,最好在与某个optional字段相组合,用来指示是否包含相应的repeated字段。
例如。
message MSG1
{
repeated fixed32 data = 1;
optional bool include_data = 2
}
当 include_data = true 时,表示要修改data字段,此时如果data字段包含0个元素则是清空。
如果include_data = false ,时表示对data字段不做任何改变,此时data字段包含0个元素或者多个元素在业务逻辑上都应该被忽略。
以上方法可以解决了repeated字段的二义性问题。
相关文章推荐
- Google Protobuf的字段
- protobuf-2.5.0/google/protobuf/repeated_field.h:322:63: error: macro "cast" requires 2 arguments, bu
- Google Protobuf开发指南
- google protobuf
- Google protobuf
- (转)[ActionScript 3] Google-ProtoBuf for AS
- Google protobuf解析消息逻辑的版本问题
- Google Protobuf 使用Demo
- protobuf repeated的使用
- Google Protocol Buffer(protobuf) 使用和研究
- java protobuf 2.6源码缺少 com.google.protobuf.DescriptorProtos
- protobuf repeated类型的使用
- linux下安装google protobuf(详细)
- 一种自动反射消息类型的 Google Protobuf 网络传输方案
- 【Google Protobuf】windows下protobuf的环境搭建(一)
- Go实战--golang中使用gRPC和Protobuf实现高性能api(golang/protobuf、google.golang.org/grpc)
- 交叉编译 google protobuf
- Google_Protobuf协议——Protobuf安装编译
- Google_Protobuf协议——Protobuf语法
- Netty与Google的protobuf使用