XmlSerializer可序列化公有可读写属性为XML,要求类有无参构造函数、属性具public get/set、类型可序列化;默认输出紧凑XML,可通过XmlWriterSettings控制缩进等格式。

用 XmlSerializer 可以轻松把对象的公有属性序列化为 XML,前提是类和属性满足基本要求。
确保类和属性符合序列化条件
XmlSerializer 只处理 public 且可读写的属性(有 get 和 set),不支持字段、private 成员、只读属性或索引器。类本身不需要特殊标记,但加 [Serializable] 没用(那是给 BinaryFormatter 用的)。
- 属性必须是 public,且同时有 public get 和 set 访问器
- 类最好有无参构造函数(否则序列化会失败)
- 避免属性类型为指针、委托、未标记
[Serializable]的自定义类等不可序列化类型
基础序列化代码示例
假设你有这样一个类:
public class Person
{
public string Name { get; set; }
public int Age { get; set; }
public DateTime BirthDate { get; set; }
}
序列化成 XML 的写法很简单:
var person = new Person { Name = "张三", Age = 28, BirthDate = new DateTime(1996, 5, 20) };
var serializer = new XmlSerializer(typeof(Person));
using (var writer = new StringWriter())
{
serializer.Serialize(writer, person);
string xml = writer.ToString(); // 得到格式化的 XML 字符串
Console.WriteLine(xml);
}
控制 XML 输出细节(可选)
默认生成的 XML 标签名就是属性名,但你可以用特性微调:
-
[XmlElement("FullName")]→ 把Name属性序列化为 -
[XmlAttribute("age")]→ 让Age作为属性而非子元素: -
[XmlIgnore]→ 完全跳过某个属性 -
[XmlRoot("Employee")]→ 把根元素名从Person改成Employee
注意编码与格式(如需换行缩进)
XmlSerializer 默认输出不带缩进的紧凑 XML。如果需要可读格式,可用 XmlWriter 配置:
var settings = new XmlWriterSettings
{
Indent = true,
IndentChars = " ",
OmitXmlDeclaration = false
};
using (var writer = XmlWriter.Create(Console.Out, settings))
{
serializer.Serialize(writer, person);
}
这样输出就会自动缩进,适合调试或展示。
基本上就这些。只要属性公开、可读写、类型支持,一行 Serialize 就搞定。










