Joh*_*ant 5 .net xml optimization performance parsing
我有一个相当大的XML文件,我需要解析为.NET类结构(映射到固定长度的记录格式并通过MQ传输).性能很重要,但并非绝对关键.
我几乎总是XPathNavigator用来读取XML文件,因为它比它更容易XmlReader.另一方面,我知道XmlReader速度快XPathNavigator,因为理论上它一次只读取一个节点,而XPathNavigator必须读取足以执行XPath,可能是整个文档.
我的问题是:它真的快多少?阅读几千个节点会有明显的区别吗?什么是我几乎不得不切换到的转折点XmlReader?或者经过XPathNavigator优化以至于它始终是一个不错的选择?
我的大多数XML经验都是在相对较小的文件上,因此我正在寻找任何使用大文件的人的输入.
据我所知,你可以获得XPathNavigator实现的唯一地方是.Xml.Linq.XDocument或XPathDocument,它们都将整个树保存在内存中.
另一方面,XmlReader可以检索和解析XML流,而无需将一组节点收集到树中.
因此,假设您以仅向前的方式收集所有必需的数据,那么对于大型数据集,XmlReader应该在以下基础上执行XPathNavigator: -