我正在尝试使用伟大的Protobuf-NET序列化模型。我不能使用属性(对象在编译时是未知的),所以我构造了一个TypeModel。 我的对象模型由类 TestDataObject 组成,该类具有 ITestDataExtension 的属性。抽象基类 TestDataExtensionBase 实现此接口 并且类 TestDataExtension (代码中的myDataObjectExtA)继承自此基类。
我的TypeModel构造如下:
System.IO.MemoryStream tmpMemoryStream = new System.IO.MemoryStream();
RuntimeTypeModel model = TypeModel.Create();
MetaType basetype = model.Add(typeof(TestDataObject), true);
MetaType interfaceType = model.Add(typeof(ITestDataExtension), true);
//MetaType extBaseType = interfaceType.AddSubType(100, typeof(TestDataExtensionBase));
MetaType extType = interfaceType.AddSubType(200, myDataObjectExtA.GetType());
model.Add(typeof(TestDataExtensionBase), true);
model.Add(myDataObjectA.Ext.GetType(), true);
model.CompileInPlace();
model.Serialize(tmpMemoryStream, myDataObjectA);
byte[] tmpDat = tmpMemoryStream.ToArray();
如果我运行以下命令,基类的属性不会被序列化,我需要将它们序列化 在我看来,我应该为TestDataExtensionBase添加一个子类型,如下所示:
MetaType extBaseType = interfaceType.AddSubType(100, typeof(TestDataExtensionBase));
MetaType extType = extBaseType.AddSubType(200, myDataObjectExtA.GetType());
但是这会产生一个:意外的子类型:TestDataExtension。 有谁知道我做错了什么?任何帮助将不胜感激。
答案 0 :(得分:4)
2个问题:
我认为以下是您所描述的内容......?
using System;
using ProtoBuf.Meta;
interface ITest
{
int X { get; set; }
}
abstract class TestBase : ITest
{
public int X { get; set; } // from interface
public int Y { get; set; }
}
class Test : TestBase
{
public int Z { get; set; }
public override string ToString()
{
return string.Format("{0}, {1}, {2}", X, Y, Z);
}
}
class Wrapper
{
public ITest Value { get; set; }
}
public class Program
{
static void Main()
{
var model = TypeModel.Create();
model.Add(typeof (ITest), false).Add("X")
.AddSubType(10, typeof (TestBase));
model.Add(typeof (TestBase), false).Add("Y")
.AddSubType(10, typeof (Test));
model.Add(typeof (Test), false).Add("Z");
model.Add(typeof (Wrapper), false).Add("Value");
Wrapper obj = new Wrapper {Value = new Test()
{X = 123, Y = 456, Z = 789}};
var clone = (Wrapper)model.DeepClone(obj);
Console.WriteLine(clone.Value);
}
}