如果没有空格分隔符,为什么XmlReader会跳过所有其他元素?

当我尝试使用LINQ XmlReader类解析XML时,我看到了奇怪的行为。 下面的测试用例:看起来我是否使用(XElement)XNode.ReadFrom(xmlReader)或XmlReader上的一个Read()方法,它错过了输入XML中的第二个bar元素。 如果在之间添加了任何空格,那么它将正确解析第二个bar元素。

有没有人知道为什么输入流搞砸了以及如何解决这个问题?

  [Test] [Explicit] public void ShouldParseCorrectNumberOfElements() { var xml = @"wtfwtf2"; XmlReader xmlReader = XmlReader.Create(new MemoryStream(Encoding.UTF8.GetBytes(xml))); int count = 0; xmlReader.MoveToContent(); while (xmlReader.Read()) { if (xmlReader.NodeType == XmlNodeType.Element && xmlReader.Name == "bar") { var element = xmlReader.ReadOuterXml(); Console.WriteLine("just got an " + element); count++; } } Assert.AreEqual(2, count); } 

您正在调用ReadOuterXml ,它将使用该元素并将“光标”放在下一个元素之前。 然后再次调用Read ,将光标移动(例如,移动到元素中的文本节点)。

这是你的循环的替代方案:

 while (!xmlReader.EOF) { Console.WriteLine(xmlReader.NodeType); if (xmlReader.NodeType == XmlNodeType.Element && xmlReader.Name == "bar") { var element = xmlReader.ReadOuterXml(); Console.WriteLine("just got an " + element); count++; } else { xmlReader.Read(); } } 

您是否可以通过在while循环条件中调用Read()函数,然后在循环内调用ReadOuterXml()函数来跳过一行?