3

我正在使用 protobuf-net 版本 2.0.0.640 来序列化一些数据,如下所示。

[ProtoContract(ImplicitFields = ImplicitFields.AllFields)]
public interface ITestMessage
{

}

[ProtoContract(ImplicitFields = ImplicitFields.AllFields)]
public class MyOrder : ITestMessage
{
    public int Amount { get; set; }
}

[ProtoContract(ImplicitFields = ImplicitFields.AllFields)]
public class MyOrderWrapper
{
    public MyOrder Order { get; set; }
}

[TestMethod]
public void TestOrderSerialize()
{
    var order = new MyOrder() {Amount = 10};
    var orderWrapper = new MyOrderWrapper() { Order = order };

    using (var file = File.Create("C:\\temp\\order.bin"))
    {
        Serializer.Serialize<MyOrderWrapper>(file, orderWrapper);
    }
}

现在,如果我通过代码声明“ITestMessage”和“MyOrder”之间的继承依赖关系:

RuntimeTypeModel.Default[typeof(ITestMessage)].AddSubType(2, typeof(MyOrder));

尝试反序列化以前保存的数据时出现以下错误。“没有为 ITestMessage 找到无参数构造函数”。

[TestMethod]
public void TestOrderDeserialize()
{
    RuntimeTypeModel.Default[typeof(ITestMessage)].AddSubType(2, typeof(MyOrder));

    MyOrderWrapper orderWrapper;
    using (var file = File.OpenRead("C:\\temp\\order.bin"))
    {
        orderWrapper = Serializer.Deserialize<MyOrderWrapper>(file);
    }
}

有人可以解释为什么当“MyOrderWrapper”在继承层次结构中没有引用任何高于“MyOrder”的东西时会发生这种情况。

另外,为什么当我在 'ITestMessage' 上明确包含 '[ProtoInclude(2, typeof(MyOrder))]' 时它会起作用

谢谢

4

1 回答 1

1

基本上,就序列化程序而言,这是一个重大变化——在线路层,既不存在“类”也不存在“接口”,因此在存储方面,这类似于更改类的基本类型;序列化时,根类型是MyOrder- 而在反序列化期间,根类型是ITestMessage. 这不会让它快乐。

基本上:你不能那样做。

于 2013-08-19T07:19:53.920 回答