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