- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我需要解析一个 xml 文件,它实际上是一个非常大的树结构的图像,所以我使用 XmlReader 类来“动态”填充树。每个节点仅通过 ReadSubtree() 函数传递它期望从其父节点获得的 xml block 。这样做的好处是不必担心节点何时消耗完其所有子节点。但现在我想知道这是否真的是个好主意,因为可能有数千个节点,并且在阅读 .NET 源文件时我发现每次 ReadSubtree 调用都会创建几个(可能更多)新对象,并且没有对可重用对象进行缓存(我见过)。
也许 ReadSubtree() 没有被认为被大量使用,或者也许我只是白担心,我只需要在解析文件后调用 GC.Collect()...
希望有人能对此有所启发。
提前致谢。
感谢您的精彩而富有洞察力的回答。
我深入研究了 .NET 源代码,发现它比我最初想象的要复杂。我终于放弃了在这种情况下调用此函数的想法。正如 Stefan 指出的那样,xml 读取器永远不会传递给外部人员,我可以信任解析 xml 流的代码(这是我自己编写的),所以我宁愿强制每个节点对它们的数据量负责从流中窃取比使用末尾不那么薄的 ReadSubtree() 函数只节省几行代码。
最佳答案
ReadSubTree() 为您提供了一个包装原始 XmlReader 的 XmlReader。这个新阅读器以完整文档的形式出现在消费者面前。如果您传递子树的代码认为它正在获取独立的 xml 文档,这可能很重要。例如,新 Reader 的 Depth 属性从 0 开始。它是一个非常薄的包装器,因此与直接使用原始 XmlReader 相比,您不会使用更多的资源,在您给出的示例中,它是很可能您并没有真正从子树阅读器中得到多少。
在您的情况下,最大的优势是子树阅读器不会意外读取子树。由于子树阅读器不是很昂贵,所以这种安全性可能就足够了,尽管当您需要子树看起来像文档或者您不相信代码只会读取它自己的子树时,它通常更有帮助。
如 Will 所述,您永远不想调用 GC.Collect()。它永远不会提高性能。
关于.net - 滥用 XmlReader ReadSubtree(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/114327/
我想将使用 .Net Compact Framework 3.5 制作的 Windows Mobile 应用程序降级到 .Net Compact Framework 2.0 SP2。 但是...我不知
我正在尝试从 xml 字符串中读取但是, ` XmlReader reader=XmlReader.Create(new StringReader(stringXml)` 读者总是没有。为什么没有
在以下代码段中,当我遇到一个元素时,使用 XmlReader。我想按原样阅读它,包括元素中的所有属性和命名空间装饰。使用 oXml.Name 属性,我只能获取标签名称。是否有获取标签本身的功能? oX
这可能是一个关于 XmlReader 的幼稚问题,但我还没有在 MSDN 文档中找到答案。 假设我有 XSD SchemaTest.xsd
我想做这样的事情: stringBuilder.AppendLine(" globalVar." + reader.GetAttribute(i).Name + " = " + reader[i]
使用 XMLReader 方法解析 XML 文件时,如何获取元素的父节点? $xml = new XMLReader(); $xml->XML($xmlString); while($xml->rea
这很奇怪。我有一个 WCF Message我正在尝试将正文的内容读入 XmlDocument。消息正文的内容在网络上看起来像这样(在打开 WCF 跟踪的情况下进行检查): (GMT-05:0
我有一个 Xml 文档,其中一些元素如下所示: W X Y Z ABC 我的目标是从上面的例子中得到“ABC”。我尝试查看 XmlElement 类中的 InnerText(返回“WXYZABC”
我有以下代码: for (i = 1; i <= loopsNeeded; i++) { lblCurrent.Text = string.Format("{0} of
我正在尝试将 xml 加载到 XDocument 对象中。 public void ValidateRules(XmlReader xml) { xml.MoveToContent();
我必须为我的商店解析 3 个远程 XML 文件(产品、价格、类别),其中最大的大约有 500MB+。我必须解析它们并插入到 mysql 数据库中。 我可以从两种格式中选择 所有 3 个 XML 文件压
我正在尝试使用 XMLReader ( https://github.com/amarcadet/XMLReader ) 在 objective-c 中制作一个将解析 xml 文档的应用程序:
代码如下: string str = "AppleMango"; using (XmlReader xmlReader = XmlReader.Create(new StringReader(str)
我了解我们如何使用如下代码示例.. public class Sample { public static void Main() { using (XmlReader
我正在使用 XmlReader 读取非常大的 XML 文件(超过 6GB 的数据)以加快一切速度并且工作得非常好。 我在另一个线程中执行此操作(不使用后台工作程序)并且我不知道如何更新进度条,因为 X
关注此introduction可以通过导入命名空间 System.Xml 来使用 XMLReader 类。在我的 Visual Studio 项目中,我使用 .NET 4.0,但 System.Xml
我正在使用以下代码使用 XmlReader 读取一些 XML: XmlReaderSettings settings = new XmlReaderSettings(); settings.Valid
好的,所以我有这个 XML 文件: Iron Repeater true 19 19 50 18 1 1 5 39
为什么我应该将 XMLReader 与 SAXParser 一起使用?我经常看到这种用法: sp = spf.newSAXParser(); XMLReader xr
我有这个 xml 文件。 8.582207 3 true
我是一名优秀的程序员,十分优秀!