使用c# . net 2.0,我有一个组合数据类,它确实有[Serializable]属性。我正在创建一个XMLSerializer类并将其传递到构造函数中:
XmlSerializer serializer = new XmlSerializer(typeof(DataClass));
我得到一个异常说:
有错误反射类型。
在数据类内部有另一个复合对象。这是否也需要有[Serializable]属性,或者通过将它放在顶部对象上,它是否递归地应用到内部的所有对象?
使用c# . net 2.0,我有一个组合数据类,它确实有[Serializable]属性。我正在创建一个XMLSerializer类并将其传递到构造函数中:
XmlSerializer serializer = new XmlSerializer(typeof(DataClass));
我得到一个异常说:
有错误反射类型。
在数据类内部有另一个复合对象。这是否也需要有[Serializable]属性,或者通过将它放在顶部对象上,它是否递归地应用到内部的所有对象?
当前回答
我也有同样的问题,在我的例子中,对象有一个ReadOnlyCollection。集合必须实现Add方法才能序列化。
其他回答
我遇到了类似的问题,结果是序列化器无法区分具有相同名称的两个类(一个是另一个的子类)。内部异常是这样的:
“BaseNamespace类型。Class1和basenamspace . subnamespace。Class1'都使用XML类型名,'Class1',来自命名空间。使用XML属性为该类型指定唯一的XML名称和/或名称空间。
BaseNamespace.SubNamespace的地方。Class1是basenamspace .Class1的一个子类。
我需要做的是添加一个属性到一个类(我添加到基类):
[XmlType("BaseNamespace.Class1")]
注意:如果你有更多的类层,你需要为它们添加一个属性。
我认为最常见的原因是:
- the object being serialized has no parameterless constructor
- the object contains Dictionary
- the object has some public Interface members
我一直在使用NetDataSerialiser类来序列化 我的域类。NetDataContractSerializer类。
域类在客户机和服务器之间共享。
到目前为止,我有一个稍微不同的解决方案,所以对于任何未来的文明,这里是我的!
我已经声明了一个“时间”的数据类型,因为原始类型是TimeSpan,随后更改为字符串:
[System.Xml.Serialization.XmlElementAttribute(DataType="time", Order=3)]
然而,实际的类型是字符串
public string TimeProperty {
get {
return this.timePropertyField;
}
set {
this.timePropertyField = value;
this.RaisePropertyChanged("TimeProperty");
}
}
通过删除DateType属性,Xml可以被序列化
[System.Xml.Serialization.XmlElementAttribute(Order=3)]
public string TimeProperty {
get {
return this.timePropertyField;
}
set {
this.timePropertyField = value;
this.RaisePropertyChanged("TimeProperty");
}
}
我刚刚得到了同样的错误,并发现类型IEnumerable<SomeClass>的属性是问题所在。IEnumerable似乎不能直接序列化。
相反,可以使用List<SomeClass>。