【发布时间】:2013-10-06 06:15:56
【问题描述】:
我正在尝试使用DataContractSerializer 来序列化一个简单的对象:
public class MyType {
public string MyValue { get; set; }
}
我进行了广泛的研究,发现according to MSDN,与流行的看法相反,属性[DataContract]是可选的,如果没有在类上指定属性,那么所有公共读/写属性和字段都会被序列化。事实上,当我这样序列化它时 - 它按预期工作。
现在,如果我还在类上添加 [Serializable] 属性,我会得到一个不同的序列化,其中包含臭名昭著的前缀“k__BackingField”(因为我的属性是自动属性)。
我的问题:
- 谁能解释为什么DataContractSerializer 在有和没有[Serializable] 属性的情况下会有不同的行为?不是技术解释(可能类似于“在这种情况下 XmlObjectSerializer 的基类正在接管”),而是设计原因。我看不出这种不同的序列化有何用处。如果有的话 - 它会破坏向后兼容性。建议对 Microsoft 进行更改是否有意义?
- 如果我不想检查整个庞大的数据模型并使用 [DataContract] 和 [DataMember] 装饰所有内容 - 是否有更通用的方法来告诉 DataContractSerializer 或 WCF 基础架构(通过服务合同属性或类似的),以序列化在其默认(读取:未修饰)行为中标记为 [Serializable] 的类?不幸的是,属性 [XmlSerializerFormat] 不适合我,我需要坚持使用 WCF 的 DataContractSerializer。
【问题讨论】:
标签: c# serialization .net-4.5 datacontractserializer serializableattribute