XmlDocument 是基于 W3C DOM 的传统 XML 类,操作冗长、不支持 LINQ;XDocument 是 LINQ to XML 的现代轻量级 API,语法简洁、强类型查询、性能更优,新项目优先选用。

XmlDocument 是 .NET Framework 早期的 XML 处理类,基于 W3C DOM 标准;XDocument 是 LINQ to XML 引入的现代轻量级 API,更符合 C# 开发习惯,语法简洁、功能集成度高。
设计哲学与 API 风格不同
XmlDocument 遵循传统 DOM 模型:节点树结构严格,所有操作需通过 XmlNode 及其子类(如 XmlElement、XmlAttribute)完成,方法名冗长(如 CreateElement、AppendChild),且大量使用 string 参数和类型转换。
XDocument 基于函数式思想,支持链式调用和初始化器语法,构造 XML 更直观。例如:
var doc1 = new XmlDocument();
var root = doc1.CreateElement("root");
var child = doc1.CreateElement("item");
child.InnerText = "abc";
root.AppendChild(child);
doc1.AppendChild(root);
var doc2 = new XDocument(
new XElement("root",
new XElement("item", "abc")
)
);
对 LINQ 查询的支持程度差异大
XmlDocument 不原生支持 LINQ,查询需配合 SelectNodes 或 GetElementsByTagName,返回 XmlNodeList,再手动遍历转换,代码繁琐且类型不安全。
XDocument 完全集成 LINQ to XML,可直接用 Descendants()、Elements()、Where()、FirstOrDefault() 等方法,返回强类型的 IEnumerable,支持 lambda 表达式和查询语法。
本文档主要讲述的是关于Objective-C手动内存管理的规则;在ios开发中Objective-C 增加了一些新的东西,包括属性和垃圾回收。那么,我们在学习Objective-C之前,最好应该先了解,从前是什么样的,为什么Objective-C 要增加这些支持。有需要的朋友可以下载看看
- 查找所有 name 元素:
doc.Descendants("name") - 筛选带特定属性的元素:
doc.Root.Elements().Where(e => (string)e.Attribute("type") == "user") - 提取值并转为对象列表:
doc.Descendants("person").Select(p => new { Name = p.Element("name")?.Value, Age = (int?)p.Element("age") }).ToList()
性能与内存占用有实际差距
XmlDocument 加载时会构建完整 DOM 树,包含注释、空白文本、处理指令等所有节点,内存占用高,尤其处理大文件时明显;它还要求显式管理节点所有权(如 ImportNode),容易出错。
XDocument 虽也是内存驻留模型,但节点类型更精简(XElement、XAttribute 等),默认忽略空白文本(除非设置 LoadOptions.PreserveWhitespace),序列化/反序列化更快,且支持 Parse、Load、Save 的异步重载(.NET Core/.NET 5+)。
- 加载时跳过空白:
XDocument.Load(stream, LoadOptions.None) - 异步保存:
await doc.SaveAsync(writer, SaveOptions.None, cancellationToken) - 从字符串解析更安全:
XDocument.Parse(xmlString, LoadOptions.None)(不会因空白或 BOM 报错)
兼容性与适用场景建议
XmlDocument 仍保留在所有 .NET 版本中,适合维护老项目、需要严格 DOM 兼容(如与 JavaScript DOM 交互)、或依赖第三方组件(如某些 WebService 客户端)的场景。
XDocument 是当前推荐方案,适用于新开发、注重可读性与开发效率、需频繁查询/修改 XML、或与其他 LINQ 数据源(如 List、数据库结果)协同处理的场景。注意:它不支持 DTD 验证、XML Schema 编译验证等高级功能(需搭配 XmlSchemaSet 和 XmlReader 使用)。
- 新项目优先选
XDocument - 需 XPath 1.0 全功能支持 → 用
XmlDocument+SelectNodes - 只需简单读写和查询 →
XDocument更省心 - 超大 XML 文件(>100MB)→ 考虑
XmlReader/XmlWriter流式处理,而非任一 DOM 类









