XmlSerializer可将对象列表序列化为XML字符串或文件,要求列表类型为List、元素类有公共无参构造函数和可读写属性,类需public且用[XmlElement]等特性控制节点名或忽略成员。

在C#中,使用XmlSerializer可以轻松将对象列表序列化为XML字符串或文件。关键点是:列表类型必须可被XmlSerializer识别(如List),且元素类型需有公共无参构造函数和可读写的公共属性。
确保类支持XML序列化
被序列化的类不能是internal或private,所有要导出的字段/属性必须是public,并建议使用属性(而非字段)。若需控制XML节点名或忽略某些成员,可添加特性:
-
[XmlElement("Item")]:指定集合中每个元素的XML标签名 -
[XmlRoot("Products")]:指定根节点名称 -
[XmlIgnore]:跳过某个属性不参与序列化
基本序列化到字符串
使用StringWriter配合XmlSerializer生成XML字符串:
var products = new List{ new Product { Id = 1, Name = "Laptop", Price = 999.99m }, new Product { Id = 2, Name = "Mouse", Price = 29.99m } }; var serializer = new XmlSerializer(typeof(List )); using var writer = new StringWriter(); serializer.Serialize(writer, products); string xml = writer.ToString(); // 得到格式化的XML字符串
序列化到文件并美化输出
默认序列化不带缩进。如需可读性更好的XML,用XmlWriter配置格式:
using var fileStream = new FileStream("products.xml", FileMode.Create);
var settings = new XmlWriterSettings
{
Indent = true,
IndentChars = " ",
NewLineChars = "\n",
Encoding = Encoding.UTF8
};
using var writer = XmlWriter.Create(fileStream, settings);
serializer.Serialize(writer, products);
注意常见问题
类型不匹配:传给XmlSerializer的类型必须与实际数据类型完全一致(如typeof(List,不能写typeof(IList)
无参构造函数缺失:如果Product没有公开的无参数构造函数,反序列化会失败,序列化虽可能成功但属不良实践
只读集合:避免用ReadOnlyCollection或IEnumerable直接序列化——改用List或Array










