【问题标题】:How does Protobuf-net support for Dictionary/KeyValuePair works?Protobuf-net 对 Dictionary/KeyValuePair 的支持如何工作?
【发布时间】:2010-10-06 15:13:57
【问题描述】:

我正在尝试了解 protobuf-net 的 Dictionary/KeyValuePair 支持。我们想使用底层二进制流和从 java 生成的 proto 文件,但是生成的 .proto 文件包含看起来像自定义类型的东西,称为 Pair_String_Int32。

有人可以解释一下吗?

我有一个像这样映射的类:

[DataContract]
public class ForwardCurve
{
    [DataMember(Order=1, IsRequired = true)]
    public string Commodity { get; set; }

    [DataMember(Order = 2, IsRequired = false)]
    public IDictionary<string, int> DictValue { get; set; }

    [DataMember(Order = 3, IsRequired = false)]
    public IList<string> ListValue { get; set; }

}

使用 Serializer.GetProto 生成的 .proto 文件将是:

message ForwardCurve {
   required string Commodity = 1;
   repeated Pair_String_Int32 DictValue = 2;
   repeated string ListValue = 3;
}

那么什么是 Pair_String_Int32(以及进入 protobuffer 字节流的内容),有什么方法可以映射它,以便 protobuf 通过使用 protoc 可以在 Java 中创建等效的映射代码?

【问题讨论】:

    标签: protocol-buffers protobuf-net


    【解决方案1】:

    要让这个工作起来,在生成的 .proto 文件中添加一条新消息,如下所示。

    message Pair_String_Int32 {
     required string Key = 1;
     required int32 Value = 2;    
    }
    

    那么protoc就可以为Java创建相应的代码了。

    【讨论】:

      【解决方案2】:

      我可以稍后检查(我现在在 iPod 上),但我相信它只是一个“重复”的一组虚拟类型,成员 key=1 value=2(使用每个默认类型 - 所以 c#字符串映射到原始字符串等)。我正在为 v2 重新实现 GetProto,所以我会尽量确保这些虚拟类型包含在输出中。

      【讨论】:

      • 我通过在生成的 .proto 文件中添加一条额外的消息来完成这项工作。如果 GetProto 生成更完整,那就太棒了。
      猜你喜欢
      • 1970-01-01
      • 2012-09-16
      • 1970-01-01
      • 1970-01-01
      • 2013-06-17
      • 1970-01-01
      • 1970-01-01
      • 2016-02-15
      • 1970-01-01
      相关资源
      最近更新 更多