1
[Serializable]
[ProtoContract]
public class DataWrapper
{
    [ProtoMember(1)]
    public double[] Data = new double[] { 1, 2, 3, 4 };
}

class Program
{
    static void Main(string[] args)
    {

        Dictionary<int, DataWrapper> serialized = new Dictionary<int, DataWrapper>();
        Dictionary<int, DataWrapper> deserialized;// = new Dictionary<int, OHLC>();
        for (int i = 0; i < 10; i++)
        {
            serialized.Add(i, new DataWrapper());                
        }
        using (FileStream ms = new FileStream("dictionary", FileMode.Create, FileAccess.Write))
        {
            Serializer.Serialize<Dictionary<int, DataWrapper>>(ms, serialized);
        }


        using (FileStream ms = new FileStream("dictionary", FileMode.Open, FileAccess.Read))
        {
            deserialized = Serializer.Deserialize<Dictionary<int, DataWrapper>>(ms);
        }

        Console.WriteLine("serialized {0} and deserialized {1}", serialized[0].Data.Length, deserialized[0].Data.Length);

        }
}

我期望反序列化一个长度为 4 的数组,而我收到一个长度为 8 的数组。这是一个错误,还是我在这里做错了?

请注意,代码是没有意义的。这只是试图解释我在真实场景中面临的问题

4

1 回答 1

1

我不是 Protobuf-net 专家,但这似乎与这个问题有关。我怀疑这是因为您明确地将 初始化double[]为具有 4 个元素,并且 protobuf-net 在反序列化期间“附加”了额外的 4 个元素。

作为一种解决方法,您可以在 中设置SkipConstructor=true选项,ProtoContract然后它可以按预期工作:

[ProtoContract(SkipConstructor=true)]
于 2013-04-22T10:38:14.623 回答