3

我成功序列化了以下类的实例,但是当我在收到以下错误消息后立即尝试反序列化时" Invalid field in source data: 0"

我不知道它指的是什么,因为我直接在下面找到了。我刚刚将 protobuf-net 版本更新为 2.00.614(运行时版本:2.0.50727)。

知道我是否可能忽略了一些微不足道的事情吗?

[ProtoContract]
public class TimeSeriesProperties 
{
    [ProtoMember(1)]
    public string TimeSeriesName { get; private set; }
    [ProtoMember(2)]
    public string FileName { get; private set; }
    [ProtoMember(3)]
    public string TemplateName { get; private set; }
    [ProtoMember(4)]
    public int PacketLength { get; private set; }
    [ProtoMember(5)]
    public long FileSizeBytes { get; set; }
    [ProtoMember(6)]
    public long NumberRecords { get; set; }
    [ProtoMember(7)]
    public DateTime DateTimeStart { get; set; }
    [ProtoMember(8)]
    public DateTime DateTimeEnd { get; set; }

    public TimeSeriesProperties()
    {

    }

    public TimeSeriesProperties(string timeSeriesName, string fileName, string templateName, int PacketLength)
    {
        this.TimeSeriesName = timeSeriesName;
        this.FileName = fileName;
        this.TemplateName = templateName;
        this.PacketLength = PacketLength;
    }

}

public static byte[] Serialize_ProtoBuf<T>(T serializeThis)
    {
        using (var stream = new MemoryStream())
        {
            ProtoBuf.Serializer.Serialize<T>(stream, serializeThis);
            return stream.GetBuffer();
        }
    }

    public static T Deserialize_ProtoBuf<T>(byte[] byteArray)
    {
        using (var stream = new MemoryStream(byteArray))
        {
            return ProtoBuf.Serializer.Deserialize<T>(stream);
        }
    }
4

1 回答 1

10

我见过的最常见的原因只是不正确地使用GetBuffer()on a MemoryStream。当我添加评论时,这已经是我的预感,但你已经确认了:

using (var stream = new MemoryStream())
{
    ProtoBuf.Serializer.Serialize<T>(stream, serializeThis);
    return stream.GetBuffer();
}

GetBuffer返回过的后备缓冲区。它的末尾有垃圾。使用 是完全可以的GetBuffer只要您还记录.Length,这是其中的有效数据量。这可以避免对潜在的大数组进行额外分配。但是在您的情况下,可能使用一种更简单的方法ToArray()来获取大小合适的缓冲区:

using (var stream = new MemoryStream())
{
    ProtoBuf.Serializer.Serialize<T>(stream, serializeThis);
    return stream.ToArray();
}
于 2013-01-07T13:40:46.647 回答