<p>使用XmlInclude特性或传入派生类型数组可解决C# XmlSerializer无法直接序列化继承类的问题,需在序列化前注册所有可能的子类型。</p>

在使用 C# 的 XmlSerializer 处理继承类时,不能直接序列化派生类对象到基类引用,除非显式告知序列化器可能的子类型。这是因为 XmlSerializer 是静态类型的,它需要在构造时就知道所有可能参与序列化的类型。
public class Animal
{
public string Name { get; set; }
}
public class Dog : Animal
{
public string Breed { get; set; }
}
当你尝试序列化一个 Dog 对象赋值给 Animal 变量时,会出错或丢失派生成员:
Animal animal = new Dog { Name = "Buddy", Breed = "Golden Retriever" };
var serializer = new XmlSerializer(typeof(Animal));
// 抛出异常:未将类型“Dog”注册
[XmlInclude(typeof(Dog))]
public class Animal
{
public string Name { get; set; }
}
public class Dog : Animal
{
public string Breed { get; set; }
}
现在可以正确序列化:
Animal animal = new Dog { Name = "Buddy", Breed = "Golden Retriever" };
var serializer = new XmlSerializer(typeof(Animal));
using var writer = new StringWriter();
serializer.Serialize(writer, animal);
Console.WriteLine(writer.ToString());
输出中会包含 xsi:type="Dog" 来标识实际类型:
<Animal xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="Dog">
<Name>Buddy</Name>
<Breed>Golden Retriever</Breed>
</Animal>
[XmlInclude(typeof(Dog))]
[XmlInclude(typeof(Cat))]
[XmlInclude(typeof(Bird))]
public class Animal
{
public string Name { get; set; }
}
public class Cat : Animal
{
public bool IsIndoor { get; set; }
}
Type[] derivedTypes = new Type[] { typeof(Dog), typeof(Cat) };
var serializer = new XmlSerializer(typeof(Animal), derivedTypes);
这种方式适合插件式架构或动态加载类型的情况。
基本上就这些。只要确保派生类型被注册,XmlSerializer 就能正确处理继承关系的序列化和反序列化。不复杂但容易忽略。
以上就是C# XmlSerializer如何处理继承类的序列化的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号