簡述C# XML解析方法的特點及應(yīng)用
C# XML解析方法都有哪些呢?在程序中訪問并操作XML文件一般有兩種模型:流模型和DOM(文檔對象模型)。流模型中有兩種變體——“推”模型和“拉”模型。
C# XML解析方法之“推”模型:
“推”模型也就是常說的SAX,SAX是一種靠事件驅(qū)動的模型。它每發(fā)現(xiàn)一個節(jié)點就用“推”模型引發(fā)一個事件,而我們必須編寫這些事件的處理程序,很麻煩。
C# XML解析方法之“拉”模型:
.NET中使用的是基于“拉”模型的實現(xiàn)方案。 “拉”模型在遍歷文檔時會把感興趣的文檔部分從讀取器中拉出,不需要引發(fā)事件,允許我們以編程的方式訪問文檔,這大大的提高了靈活性,“拉”模型可以選擇性的處理節(jié)點。在.NET中,“拉”模型通過XML閱讀器(XMLTextReader類)來實現(xiàn)的。該類提供Xml文件讀取的功能,它可以驗證文檔是否格式良好,如果不是格式良好的Xml文檔,該類在讀取過程中將會拋出XmlException異常。任何時候在內(nèi)存中只有當(dāng)前節(jié)點,但它是只讀的,向前的,不能在文檔中執(zhí)行向后導(dǎo)航操作。
C# XML解析方法之DOM介紹:
DOM的好處在于它允許編輯和更新XML文檔,可以隨機(jī)訪問文檔中的數(shù)據(jù),可以使用XPath查詢。但是,DOM的缺點在于它需要一次性的加載整個文檔到內(nèi)存中,對于大型的文檔,這會造成資源問題。在.NET中使用XML DOM分析器(XMLDocument)實現(xiàn)DOM模型。
因此,.NET Framework完全支持XML DOM模式,但它不支持SAX模式。.NET Framework支持兩種不同的分析模式:XML DOM分析器(XMLDocument類)和XML閱讀器(XMLTextReader類),不支持SAX分析器, 但這并不意味著它沒有提供類似SAX分析器的功能。通過XML閱讀器可以將SAX的所有的功能很容易的實現(xiàn)及更有效的運用。
C# XML解析方法的介紹就向你講解到這里,希望你對C# XML解析方法的了解和學(xué)習(xí)有所幫助。
【編輯推薦】