protocol-buffers - Protobuf3 : How to describe map of repeated string?

标签 protocol-buffers protocol-buffers-3

Official documentation about map type说:

map<key_type, value_type> map_field = N;

...where the key_type can be any integral or string type (so, any scalar type except for floating point types and bytes). The value_type can be any type.



我想定义一个 map<string, repeated string>字段,但在我的 libprotoc 3.0.0 上似乎是非法的, 提示 Expected ">" .所以我想知道是否有任何方法可以将重复的字符串放入 map 中。

一个可能的解决方法可能是:
message ListOfString {
    repeated string value = 1;
}

// Then define:
map<string, ListOfString> mapToRepeatedString = 1;

但是ListOfString这里看起来多余。

最佳答案

我有同样的需求,并得到了同样的错误。我不相信这是可能的。这是语言规范中的相关 BNF 定义。

https://developers.google.com/protocol-buffers/docs/reference/proto3-spec

messageType = [ "." ] { ident "." } messageName
mapField = "map" "<" keyType "," type ">" mapName "=" fieldNumber [ "["fieldOptions "]" ] ";"
type = "double" | "float" | "int32" | "int64" | "uint32" | "uint64"
  | "sint32" | "sint64" | "fixed32" | "fixed64" | "sfixed32" | "sfixed64"
  | "bool" | "string" | "bytes" | messageType | enumType
messageName = ident
ident = letter { letter | decimalDigit | "_" }
field = [ "repeated" ] type fieldName "=" fieldNumber [ "[" fieldOptions "]" ] ";"

“重复”关键字仅出现在字段定义中。 map 定义需要一个“类型”,其中不包括重复的关键字。

这意味着有几个选项。

  • 您可以按照您的指示在重复值周围创建一个包装器。
  • 人们定义 map 的方式较旧,它更繁琐但等效。这是语言指南中的向后兼容示例。

    https://developers.google.com/protocol-buffers/docs/proto3#maps

    消息 MapFieldEntry {
    key_type 键 = 1;
    重复 value_type 值 = 2;
    }
    重复 MapFieldEntry map_field = N;


    您需要自己将数据转换为 map ,但这在大多数语言中应该是相当简单的。在 Java 中:

    List map_field =//protobuf 中的现有列表。
    Map> = map_field.stream()
    .collect(Collectors.toMap(kv -> kv.key, kv -> kv.value));




  • 使用 google.protobuf.ListValue

    https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#listvalue

    这是来自他们众所周知的类型的无类型列表集合。
  • 关于protocol-buffers - Protobuf3 : How to describe map of repeated string?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38886789/

    相关文章:

    python - Protobuf3 : Serialize a Python object to JSON

    protocol-buffers - Protobuf3 : How to describe map of repeated string?

    java - protoc 自定义插件出错并显示程序未找到或不可执行

    c++ - 将 Protocol Buffer 定义拆分为多个 .proto 文件

    protocol-buffers - 如何使用 grpcio-tools/grpc_tools.protoc 在 proto 文件中进行相对导入

    ios - 如何为基于 autotool 的项目启用特定于 Xcode 的构建标志

    java - 如何屏蔽 Protobuf 中的某些字段

    c# - 使用 protobuf 序列化 ConcurrentQueue

    go - 无法在 Go lang 中将 int32 protobuf 分配给 int

    protocol-buffers - 如何在 protobuf 3 中定义可选字段