您好,登錄后才能下訂單哦!
這篇文章主要介紹“C# XML解析方法有哪些”,在日常操作中,相信很多人在C# XML解析方法有哪些問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”C# XML解析方法有哪些”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
在程序中訪問(wèn)并操作XML文件一般有兩種模型:流模型和DOM(文檔對(duì)象模型)。流模型中有兩種變體——“推”模型和“拉”模型。
C# XML解析方法之“推”模型:
“推”模型也就是常說(shuō)的SAX,SAX是一種靠事件驅(qū)動(dòng)的模型。它每發(fā)現(xiàn)一個(gè)節(jié)點(diǎn)就用“推”模型引發(fā)一個(gè)事件,而我們必須編寫這些事件的處理程序,很麻煩。
C# XML解析方法之“拉”模型:
.NET中使用的是基于“拉”模型的實(shí)現(xiàn)方案。 “拉”模型在遍歷文檔時(shí)會(huì)把感興趣的文檔部分從讀取器中拉出,不需要引發(fā)事件,允許我們以編程的方式訪問(wèn)文檔,這大大的提高了靈活性,“拉”模型可以選擇性的處理節(jié)點(diǎn)。在.NET中,“拉”模型通過(guò)XML閱讀器(XMLTextReader類)來(lái)實(shí)現(xiàn)的。該類提供Xml文件讀取的功能,它可以驗(yàn)證文檔是否格式良好,如果不是格式良好的Xml文檔,該類在讀取過(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查詢。但是,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類)和XML閱讀器(XMLTextReader類),不支持SAX分析器, 但這并不意味著它沒(méi)有提供類似SAX分析器的功能。通過(guò)XML閱讀器可以將SAX的所有的功能很容易的實(shí)現(xiàn)及更有效的運(yùn)用。
到此,關(guān)于“C# XML解析方法有哪些”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。