2
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 会导致不序列化此属性,就好像应用了基类属性的默认值一样。有人可以向我解释这种行为吗?有人知道解决这个问题吗?

我的目标是不序列化默认值,但更改派生类的默认值。

4

1 回答 1

1

XmlSerializer似乎只有第一个,不幸的DefaultValueAttribute是我认为没有直接的解决方法来满足您的需求。但是,您可以自己实施IXmlSerializable和做那种事情。

于 2009-10-08T08:47:08.773 回答