using System.ComponentModel;
using System.IO;
using System.Xml.Serialization;
namespace SerializerTest {
static class Program {
static void Main() {
using (TextWriter textWriter = new StreamWriter("data.xml")) {
Data data = new Data();
new XmlSerializer(typeof(Data)).Serialize(textWriter, data);
textWriter.Close();
}
using (TextWriter textWriter = new StreamWriter("exData.xml")) {
ExData exData = new ExData();
new XmlSerializer(typeof(ExData)).Serialize(textWriter, exData);
textWriter.Close();
}
}
}
public class Data {
[DefaultValue(10)] public int A { get; set; }
public Data() { A = 10; }
}
public class ExData : Data {
[DefaultValue(20)] public new int A { get; set; }
public ExData() { A = 20; }
}
}
虽然第一个序列化是我所期望的(默认值的非序列化):
<?xml version="1.0" encoding="utf-8" ?>
<Data xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" />
第二个结果是:
<?xml version="1.0" encoding="utf-8"?>
<ExData xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<A>20</A>
</ExData>
显然 XmlSerializer 采用基类的默认值,而不是采用新的值。使用“覆盖”覆盖虚拟属性会产生相同的结果。将 ExData 的属性 A 的初始化更改为 10 会导致不序列化此属性,就好像应用了基类属性的默认值一样。有人可以向我解释这种行为吗?有人知道解决这个问题吗?
我的目标是不序列化默认值,但更改派生类的默认值。