当前位置:
开发笔记 >
Android > 正文
在.NETFramework中轻松处理XML数据(3-1)
作者:karenwang05 | 来源:互联网 | 2014-05-04 00:08
??带验证的浏览器??XmlValidatingReader类实现了XmlReader类,它供给了支撑多种类型的XML验证:DTD,XML-DataReduced(XDR)架构,以及XSD,DTD和XSD都是W3C官方推荐的。而XDR是Microsoft早期用于处
??带验证的浏览器 ??XmlValidatingReader类实现了XmlReader类,它供给了支撑多种类型的XML验证:DTD,XML-Data Reduced(XDR)架构,以及XSD,DTD和XSD都是W3C官方推荐的。而XDR是Microsoft早期用于处理XML构架的一种格局。 ??你可以用XmlVlidatingReader类往验证XML文档和XML片段。XmlValidatingReader类工作在XML浏览器上面---是一个典范的XMLTextReader类实例。XMLTextReade用于读取文档的节点,但是XmlVlidatingReader根据需要的验证类型往验证每一个XML块。 ??XmlVlidatingReader类只实现了非常小的XML浏览器必备的一个功效子集。该类总是工作在一个已存在的XML浏览器上面,它监督方法和属性。假如你深进该类的结构函数,你会发明它很明显的依附一个已存在的文本浏览器。带验证的XML浏览器不能直接的从一个文件或一个URL序列化。该类的结构函数列表如下: public XmlValidatingReader(XmlReader); public XmlValidatingReader(Stream, XmlNodeType, XmlParserContext); public XmlValidatingReader(string, XmlNodeType, XmlParserContext); ??带验证的XML浏览器能分析任何的XML片段,XML片段通过一个string或者一个stream供给,也可以分析任何浏览器供给的XML文档。 ??XmlVlidatingReader类中有重大转变的方法非常少(相对其它reader类来说),另外对 Read,它有Skip和ReadTypedValue方法。Skip方法跳过当前节点所有的子节点(你不能跳过不良格局的XML文本,它是相当有用的算法),Skip方法也验证被跳过的内容。ReadTypedValue方法返回指定 XML 架构 (XSD) 类型对应的CLR类型。假如该方法找到了XSD类型对应的CLR类型,则返回CLR的类型名。假如找不到,则把该节点的值作为一个字符串值返回。 ??带验证的XML浏览器正如其名,它是一个基于节点的浏览器,它验证当前节点的结构是否符合当前的schema。验证是增量式的;它没有方法返回表现文档是否有效的布尔值。通常你都是用Read方法往读输进的XML文档。实际上,你也可以用带验证的浏览器往读XML文档。在每一步中,当前被拜访的节点的结构是否与指定的schema符合,假如不符合,抛出一个异常。图四是一个把持台利用程序,它有一个要输进文件名的命令行,最后输出验证成果。 Figure 4 Console App using System; using System.Xml; using System.Xml.Schema; class MyXmlValidApp { public MyXmlValidApp(String fileName) { try { Validate(fileName); } catch (Exception e) { Console.WriteLine('Error:\t{0}', e.Message); Console.WriteLine('Exception raised: {0}', e.GetType().ToString()); } } private void Validate(String fileName) { XmlTextReader xtr = new XmlTextReader(fileName); XmlValidatingReader vreader = new XmlValidatingReader(xtr); vreader.ValidatiOnType= ValidationType.Auto; vreader.ValidatiOnEventHandler= new ValidationEventHandler(this.ValidationEventHandle); vreader.Read(); vreader.MoveToContent(); while (vreader.Read()) {} xtr.Close(); vreader.Close(); } public void ValidationEventHandle(Object sender, ValidationEventArgs args) { Console.Write('Validation error: ' args.Message '\r\n'); } public static void Main(String[] args) { MyXmlValidApp o = new MyXmlValidApp(args[0]); return; } }
推荐阅读
本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ...
[详细]
蜡笔小新 2024-12-28 10:36:30
本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ...
[详细]
蜡笔小新 2024-12-28 12:07:46
本文探讨了Android Launcher开发中自定义View的重要性,并通过一道经典的面试题,帮助开发者更好地理解自定义View的实现细节。文章不仅涵盖了基础知识,还提供了实际操作建议。 ...
[详细]
蜡笔小新 2024-12-28 11:15:04
Søren Kierkegaard famously stated that life can only be understood in retrospect but must be lived moving forward. This perspective delves into the intricate relationship between our lived experiences and our reflections on them. ...
[详细]
蜡笔小新 2024-12-28 10:17:59
本文探讨了网络层的控制平面,包括转发和路由选择的基本原理。转发在数据平面上实现,通过配置路由器中的转发表完成;而路由选择则在控制平面上进行,涉及路由器中路由表的配置与更新。此外,文章还介绍了ICMP协议、两种控制平面的实现方法、路由选择算法及其分类等内容。 ...
[详细]
蜡笔小新 2024-12-27 22:54:11
本文将介绍如何使用 Go 语言编写和运行一个简单的“Hello, World!”程序。内容涵盖开发环境配置、代码结构解析及执行步骤。 ...
[详细]
蜡笔小新 2024-12-27 21:29:35
本文探讨了线性Kalman滤波器(LKF)在不同自由度(2、4、7)的车辆悬架系统中进行主动控制的应用。通过详细的仿真分析,展示了LKF在提升悬架性能方面的潜力,并总结了调参过程中的关键要点。 ...
[详细]
蜡笔小新 2024-12-27 20:47:55
本文探讨了Hive中内部表和外部表的区别及其在HDFS上的路径映射,详细解释了两者的创建、加载及删除操作,并提供了查看表详细信息的方法。通过对比这两种表类型,帮助读者理解如何更好地管理和保护数据。 ...
[详细]
蜡笔小新 2024-12-27 20:21:48
1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ...
[详细]
蜡笔小新 2024-12-27 19:32:17
本文详细介绍了七种经典的排序算法及其性能分析。每种算法的平均、最坏和最好情况的时间复杂度、辅助空间需求以及稳定性都被列出,帮助读者全面了解这些排序方法的特点。 ...
[详细]
蜡笔小新 2024-12-27 19:25:14
本文介绍如何利用动态规划算法解决经典的0-1背包问题。通过具体实例和代码实现,详细解释了在给定容量的背包中选择若干物品以最大化总价值的过程。 ...
[详细]
蜡笔小新 2024-12-27 19:17:15
本文详细探讨了Java中的24种设计模式及其应用,并介绍了七大面向对象设计原则。通过创建型、结构型和行为型模式的分类,帮助开发者更好地理解和应用这些模式,提升代码质量和可维护性。 ...
[详细]
蜡笔小新 2024-12-27 19:10:10
本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ...
[详细]
蜡笔小新 2024-12-27 18:51:49
题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ...
[详细]
蜡笔小新 2024-12-27 18:14:31
本文详细介绍C++中实现KMP算法的方法,探讨其在字符串匹配问题上的优势。通过对比暴力匹配(BF)算法,展示KMP算法如何利用前缀表优化匹配过程,显著提升效率。 ...
[详细]
蜡笔小新 2024-12-27 14:45:30
karenwang05
这个家伙很懒,什么也没留下!