XmlSerializer可将C#对象序列化为XML字符串,要求类及成员为public、含public无参构造函数、属性需有get/set访问器,支持集合与嵌套对象,可通过XmlWriterSettings控制格式。

用 XmlSerializer 类就能把 C# 对象转成 XML 字符串,关键是对象要满足可序列化要求,比如有公共无参构造函数、公共属性、不能是匿名类型或指针类型。
确保类支持 XML 序列化
被序列化的类需要是 public 的,所有要导出的字段或属性也得是 public,并且推荐用属性(get/set)而不是字段。如果不想某个属性参与序列化,加 [XmlIgnore] 特性。
- 必须有 public 无参构造函数(编译器自动生成也算)
- 属性要有 public getter 和 setter(只读属性无法反序列化)
- 避免使用 ref、out、指针、委托、事件等不可序列化成员
基础序列化代码示例
用 StringWriter + XmlSerializer 把对象写入字符串:
var person = new Person { Name = "张三", Age = 28 };
var serializer = new XmlSerializer(typeof(Person));
using var writer = new StringWriter();
serializer.Serialize(writer, person);
string xml = writer.ToString(); // 得到 XML 字符串控制 XML 输出格式(可选)
默认输出紧凑无缩进。如需缩进、换行、指定编码,可用 XmlWriter 配合 XmlWriterSettings:
本文档主要讲述的是JSON.NET 简单的使用;JSON.NET使用来将.NET中的对象转换为JSON字符串(序列化),或者将JSON字符串转换为.NET中已有类型的对象(反序列化?)。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看
- 设置
Indent = true让 XML 更易读 - 设置
Encoding = Encoding.UTF8明确编码(避免 BOM 或乱码) - 用
XmlWriter.Create(...)创建带配置的写入器
示例:
var settings = new XmlWriterSettings { Indent = true, Encoding = Encoding.UTF8 };
using var writer = XmlWriter.Create(new StringWriter(), settings);
serializer.Serialize(writer, person);处理集合和嵌套对象
XmlSerializer 原生支持数组、List、Dictionary(但字典需额外处理,建议用 List
- 集合属性建议用
List,别用IEnumerable(接口无法实例化) - 若想自定义集合元素标签名,加
[XmlElement("Item")] - 根节点名默认是类名,可用
[XmlRoot("People")]修改
基本上就这些。不复杂但容易忽略无参构造和属性可访问性。









