我有最好描述为“类似洋葱”的数据,因为每个外层都建立在它下面的一层之上。下面您将看到一个大大简化的版本(我的版本更深几层,但在每个级别都表现出相同的行为)。
[CollectionDataContract]
public abstract class AbstractTestGroup : ObservableCollection<AbstractTest>
{
[DataMember]
public abstract string Name { get; set; }
}
[CollectionDataContract]
[KnownType(typeof(Test))]
public class TestGroup : AbstractTestGroup
{
public override string Name
{
get { return "TestGroupName"; }
set { }
}
[DataMember]
public string Why { get { return "Why"; } set { } }
}
[DataContract]
public abstract class AbstractTest
{
[DataMember]
public abstract string SayHello { get; set; }
}
[DataContract]
public class Test : AbstractTest
{
//Concrete class - members in this class get serialized
[DataMember]
public string Month { get { return "June"; } set { } }
public override string SayHello { get { return "HELLO"; } set { } }
}
我TestGroup
使用. Test
_ .Add
_ObservableCollection
当我序列化和反序列化这个结构时,我得到以下信息
<TestGroup xmlns="http://schemas.datacontract.org/2004/07/WpfApplication2" xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
<AbstractTest i:type="Test">
<SayHello>HELLO</SayHello>
<Month>June</Month>
</AbstractTest>
</TestGroup>
输出已离开DataMember
s in TestGroup
。随着我对洋葱的深入了解,不DataMember
包括更高的 s(即使来自抽象类)。我曾尝试添加[KnownType(typeof(TestGroup))]
两者TestGroup
但AbstractTestGroup
没有成功。
问题:为什么我不能DataMember
Why
在TestGroup
课堂上序列化?
后续问题:是否有另一种方法来序列化和反序列化这种形状的结构?我计划在本地使用输出来“加载”用户指定的配置。如果可以避免的话,我宁愿不必指定我自己的序列化方案。
对于那些感兴趣的人来说,我是如何生成类、序列化和反序列化它的。
TestGroup tg = new TestGroup();
tg.Add(new Test());
DataContractSerializer ser = new DataContractSerializer(typeof(TestGroup));
MemoryStream memoryStream = new MemoryStream();
ser.WriteObject(memoryStream, tg);
memoryStream.Seek(0, SeekOrigin.Begin);
string str;
using (StreamReader sr = new StreamReader(memoryStream))
str = sr.ReadToEnd();
编辑:为了什么值得我尝试改为使用Serializable
并遇到同样的问题。