C#中流模型的作用是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
访问的两种模型:
在程序中访问进而操作XML文件一般有两种模型,分别是使用DOM(文档对象模型)和流模型,使用DOM的好处在于它允许编辑和更新XML文档,可以随机访问文档中的数据,可以使用XPath查询,但是,DOM的缺点在于它需要一次性的加载整个文档到内存中,对于大型的文档,这会造成资源问题。流模型很好的解决了这个问题,因为它对XML文件的访问采用的是流的概念,也就是说,任何时候在内存中只有当前节点,但它也有它的不足,它是只读的,仅向前的,不能在文档中执行向后导航操作。虽然是各有千秋,但我们也可以在程序中两者并用实现优劣互补嘛,呵呵,这是题外话了!我们今天主要讨论XML的读取,那我们就详细讨论一下C#流模型吧!
C#流模型中的变体:
C#流模型每次迭代XML文档中的一个节点,适合于处理较大的文档,所耗内存空间小。流模型中有两种变体——“推”模型和“拉”模型。
推模型也就是常说的SAX,SAX是一种靠事件驱动的模型,也就是说:它每发现一个节点就用推模型引发一个事件,而我们必须编写这些事件的处理程序,这样的做法非常的不灵活,也很麻烦。
.NET中使用的是基于“拉”模型的实现方案,“拉”模型在遍历文档时会把感兴趣的文档部分从读取器中拉出,不需要引发事件,允许我们以编程的方式访问文档,这大大的提高了灵活性,在性能上“拉”模型可以选择性的处理节点,而SAX每发现一个节点都会通知客户机,从而,使用“拉”模型可以提高Application的整体效率。在.NET中“拉”模型是作为XmlReader类实现的,下面看一下该类的继承结构:
我们今天来讲一下该体系结构中的XmlTextReader类,该类提供对Xml文件进行读取的功能,它可以验证文档是否格式良好,如果不是格式良好的 Xml文档,该类在读取过程中将会抛出XmlException异常,可使用该类提供的一些方法对文档节点进行读取,筛选等操作以及得到节点的名称和值,请牢记:XmlTextReader是基于C#流模型的实现,打个不恰当的比喻,XML文件就好象水源,闸一开水就流出,流过了就流过了不会也不可以往回流。内存中任何时候只有当前节点,你可以使用 XmlTextReader类的Read()方法读取下一个节点。好了,说了这么多来看一个例子,编程要注重实际对吧。看代码前先看下运行效果吧!
Example1按纽遍历文档读取数据,Example2,Example3按纽得到节点类型,Example4过滤文档只获得数据内容,Example5得到属性节点,Example6按纽得到命名空间,Example7显示整个XML文档,为此,我专门写一个类来封装以上功能,该类代码如下:
namespace XMLReading { using System; using System.Xml; using System.Windows.Forms; using System.ComponentModel; /// <summary> /// Xml文件读取器 /// </summary> public class XmlReader : IDisposable { private string _xmlPath; private const string _errMsg = "Error Occurred While Reading "; private ListBox _listBox; private XmlTextReader xmlTxtRd; #region XmlReader 的构造器 public XmlReader() { this._xmlPath = string.Empty; this._listBox = null; this.xmlTxtRd = null; } /// <summary> /// 构造器 /// </summary> /// <param name="_xmlPath">xml文件绝对路径</param> /// <param name="_listBox">列表框用于显示xml</param> public XmlReader(string _xmlPath, ListBox _listBox) { this._xmlPath = _xmlPath; this._listBox = _listBox; this.xmlTxtRd = null; } #endregion #region XmlReader 的资源释放方法 /// <summary> /// 清理该对象所有正在使用的资源 /// </summary> public void Dispose() { this.Dispose(true); GC.SuppressFinalize(this); } /// <summary> /// 释放该对象的实例变量 /// </summary> /// <param name="disposing"></param> protected virtual void Dispose(bool disposing) { if (!disposing) return; if (this.xmlTxtRd != null) { this.xmlTxtRd.Close(); this.xmlTxtRd = null; } if (this._xmlPath != null) { this._xmlPath = null; } } #endregion #region XmlReader 的属性 /// <summary> /// 获取或设置列表框用于显示xml /// </summary> public ListBox listBox { get { return this._listBox; } set { this._listBox = value; } } /// <summary> /// 获取或设置xml文件的绝对路径 /// </summary> public string xmlPath { get { return this._xmlPath; } set { this._xmlPath = value; } } #endregion /// <summary> /// 遍历Xml文件 /// </summary> public void EachXml() { this._listBox.Items.Clear(); this.xmlTxtRd = new XmlTextReader(this._xmlPath); try { while(xmlTxtRd.Read()) { this._listBox.Items.Add(this.xmlTxtRd.Value); } } catch(XmlException exp) { throw new XmlException(_errMsg + this._xmlPath + exp.ToString()); } finally { if (this.xmlTxtRd != null) this.xmlTxtRd.Close(); } } /// <summary> /// 读取Xml文件的节点类型 /// </summary> public void ReadXmlByNodeType() { this._listBox.Items.Clear(); this.xmlTxtRd = new XmlTextReader(this._xmlPath); try { while(xmlTxtRd.Read()) { this._listBox.Items.Add(this.xmlTxtRd.NodeType.ToString()); } } catch(XmlException exp) { throw new XmlException(_errMsg + this._xmlPath + exp.ToString()); } finally { if (this.xmlTxtRd != null) this.xmlTxtRd.Close(); } }
看完上述内容,你们掌握C#中流模型的作用是什么的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。