我现在正在学习XmlDocument,但我刚刚遇到XDocument,当我试图搜索它们的差异或好处时,我找不到有用的东西,你能告诉我为什么你会使用一个而不是另一个吗?
当前回答
XmlDocument非常适合熟悉XML DOM对象模型的开发人员。它已经存在了一段时间,或多或少地与W3C标准相对应。它支持手动导航和XPath节点选择。
XDocument支持。net 3.5中的LINQ to XML特性。它大量使用IEnumerable<>,并且更容易在c#中使用。
这两种文档模型都要求将整个文档加载到内存中(例如,与XmlReader不同)。
其他回答
XDocument是从LINQ到XML API, XmlDocument是用于XML的标准dom风格API。如果您非常了解DOM,并且不想学习从LINQ到XML,那么可以使用XmlDocument。如果你对这两个都不熟悉,看看这个页面,比较一下这两个,然后选择一个你更喜欢的外观。
我刚刚开始使用LINQ to XML,我喜欢使用函数结构创建XML文档的方式。真的很好。相比之下,DOM比较笨拙。
如果您使用的是。net 3.0或更低版本,则必须使用XmlDocument,也就是经典的DOM API。同样地,你会发现有其他一些api也会期望这样做。
但是,如果可以选择的话,我强烈建议使用XDocument,也就是LINQ to XML。创建和处理文档要简单得多。例如,它是以下两者之间的区别:
XmlDocument doc = new XmlDocument();
XmlElement root = doc.CreateElement("root");
root.SetAttribute("name", "value");
XmlElement child = doc.CreateElement("child");
child.InnerText = "text node";
root.AppendChild(child);
doc.AppendChild(root);
and
XDocument doc = new XDocument(
new XElement("root",
new XAttribute("name", "value"),
new XElement("child", "text node")));
在LINQ to XML中使用名称空间非常容易,这与我见过的任何其他XML API都不同:
XNamespace ns = "http://somewhere.com";
XElement element = new XElement(ns + "elementName");
// etc
LINQ to XML也可以很好地与LINQ一起工作——它的构造模型允许你非常容易地构建带有子元素序列的元素:
// Customers is a List<Customer>
XElement customersElement = new XElement("customers",
customers.Select(c => new XElement("customer",
new XAttribute("name", c.Name),
new XAttribute("lastSeen", c.LastOrder)
new XElement("address",
new XAttribute("town", c.Town),
new XAttribute("firstline", c.Address1),
// etc
));
它更具有声明性,这符合一般的LINQ风格。
Now as Brannon mentioned, these are in-memory APIs rather than streaming ones (although XStreamingElement supports lazy output). XmlReader and XmlWriter are the normal ways of streaming XML in .NET, but you can mix all the APIs to some extent. For example, you can stream a large document but use LINQ to XML by positioning an XmlReader at the start of an element, reading an XElement from it and processing it, then moving on to the next element etc. There are various blog posts about this technique, here's one I found with a quick search.
XmlDocument非常适合熟悉XML DOM对象模型的开发人员。它已经存在了一段时间,或多或少地与W3C标准相对应。它支持手动导航和XPath节点选择。
XDocument支持。net 3.5中的LINQ to XML特性。它大量使用IEnumerable<>,并且更容易在c#中使用。
这两种文档模型都要求将整个文档加载到内存中(例如,与XmlReader不同)。
另外,请注意XDocument在Xbox 360和Windows Phone OS 7.0中是受支持的。 如果您以它们为目标,则为XDocument开发或从XmlDocument迁移。
我相信XDocument进行了更多的对象创建调用。我认为在处理大量XML文档时,XMLDocument会更快。
这种情况发生在管理扫描数据时。许多扫描工具以XML格式输出数据(原因很明显)。如果必须处理大量这样的扫描文件,我认为使用XMLDocument会有更好的性能。
推荐文章
- .NET中的Map和Reduce
- 我如何能使一个组合框不可编辑的。net ?
- .NET反射的成本有多高?
- 实体框架回滚并移除不良迁移
- 将流转换为字符串并返回
- 在c#中检查字符串是否只包含数字的最快方法
- IEquatable和重写Object.Equals()之间的区别是什么?
- 创建一个堆栈大小为默认值50倍的线程有什么危险?
- 转换JSON字符串到JSON对象c#
- 显示两个datetime值之间的小时差值
- 如何设置enum为空
- 选择Enum类型的默认值而无需更改值
- 我如何设置在一个组合框中选择的项目,以匹配我的字符串使用c# ?
- String与StringBuilder
- 如何在ASP中使用ILogger进行单元测试。网络核心