使用 using 语句创建 XmlWriter 是确保正确关闭和刷新的关键,它自动调用 Dispose()(等效 Flush() + Close()),避免资源泄漏或内容截断;手动调用易遗漏或出错。

确保 XmlWriter 正确关闭和刷新的关键是使用 using 语句,它会自动调用 Dispose()(内部等效于 Flush() + Close()),避免资源泄漏或内容截断。
必须用 using 包裹 XmlWriter 实例
XmlWriter 实现了 IDisposable,其 Dispose() 方法会强制刷新缓冲区并关闭底层流。手动调用 Close() 或 Flush() 容易遗漏或顺序错误,而 using 能保证即使发生异常也执行清理。
- ✅ 正确写法(推荐):
using (var writer = XmlWriter.Create("output.xml"))
{
writer.WriteStartElement("root");
writer.WriteString("hello");
writer.WriteEndElement();
} // ← 自动 Flush + Close,文件完整写入磁盘
- ❌ 错误写法(风险高):
var writer = XmlWriter.Create("output.xml");
writer.WriteStartElement("root");
// 忘记 Close() → 文件可能为空或不完整
// 异常时更危险:资源未释放、文件句柄泄漏
避免在 using 外继续使用 writer
using 块结束后,writer 对象已释放,再访问会抛出 ObjectDisposedException。不要试图复用或延迟关闭。
- 不要把
XmlWriter存为类字段长期持有 - 不要在
using块外调用Write...或Flush() - 若需分阶段写入,应重新创建
XmlWriter,或改用XDocument构建内存树再保存
注意底层流的生命周期
如果传入自定义 Stream(如 FileStream)给 XmlWriter.Create(),默认情况下 XmlWriter.Dispose() 也会关闭该流。如需复用流,要显式设置 new XmlWriterSettings { CloseOutput = false }:
var settings = new XmlWriterSettings { CloseOutput = false };
using (var fs = new FileStream("output.xml", FileMode.Create))
using (var writer = XmlWriter.Create(fs, settings))
{
writer.WriteStartElement("data");
writer.WriteValue(42);
writer.WriteEndElement();
} // fs 仍打开,可继续写入其他内容
调试时检查输出是否完整
若 XML 文件结尾缺失 或报“XML 文档结构不正确”,大概率是 XmlWriter 未正确关闭。可在关闭前加日志,或用文本编辑器查看文件末尾:
- 确认
using块确实执行到了结束大括号 - 检查是否在
using内部提前return或抛异常而未捕获 - 必要时启用
XmlWriterSettings.ConformanceLevel = ConformanceLevel.Document让验证更严格










