日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Android讀寫XML(中)

系統(tǒng) 2355 0

注明:本文轉(zhuǎn)自 http://www.moandroid.com.

前面在 Android讀寫XML(上)——package說明 中,詳細介紹了使用 DOM方法讀取XML文檔,由于使用DOM方法需要將整個XML文檔加載內(nèi)存中,對系統(tǒng)資源占用比較多,這對內(nèi)存比較緊張的Android系統(tǒng)來說,使用DOM方法讀取XML文檔會有很大的限制。 使用SAX方法讀取XML,對內(nèi)存資源的占用的比較少,因此在嵌入式設(shè)備中極力推薦使用,Android也不例外,本篇幅詳細說明Android中如何使用SAX讀取XML文檔。

SAX采用基于事件驅(qū)動的處理方式,它將XML文檔轉(zhuǎn)換成一系列的事件,由單獨的事件處理器來決定如何處理。為了了解如何使用SAX API處理XML文檔,這里介紹一下SAX所使用的基于事件驅(qū)動的處理模式。

基于事件驅(qū)動的處理模式

基于事件的處理模式主要圍繞著 事件源 以及 事件處理器 來工作的。一個可以產(chǎn)生事件的對象被稱為 事件源 ,而可以對事件產(chǎn)生響應(yīng)的對象就被叫做 事件處理器 。事件源與事件處理對象是通過在事件源中的事件注冊方法連接的。當事件源產(chǎn)生時間后,調(diào)用事件處理器相應(yīng)的方法,一個事件獲得處理。當在事件源調(diào)用事件處理器中特定方法的時候,會傳遞個事件標志以及其響應(yīng)事件的狀態(tài)信息,這樣事件處理器才能夠根據(jù)事件信息來決定自己的行為。

在SAX接口中,事件源是org.xml.sax包中的XMLReader,它通過parser()方法來開始解析XML文檔,并根據(jù)文檔的內(nèi)容產(chǎn)生事件。而事件處理器則是org.xml.sax包中的ContentHander、DTDHander、ErrorHandler,以及EntityResolver這4個接口,它們分別處理事件源在解析XML文檔過程中產(chǎn)生的不同種類的事件。而事件源XMLReader與這4個事件處理器的連接是通過在XMLReader中的相應(yīng)事件處理器注冊方法setXXXX()來完成的,詳細介紹請見下表:

以上的4個事件源處理器接口,在開發(fā)中沒有必要直接從這4個接口直接繼承,因為org.xml.sax.helper包為我們提供了類DefaultHandler,其繼承了這4個個接口,在實際開發(fā)中直接從DefaultHandler繼承并實現(xiàn)相關(guān)函數(shù)就可以了。在這4個接口中,最重要的是ContentHanlder接口,下面就其中的方法加以說明,如下:

以上就是解析一個XML文檔,事件處理的過程。這里我們對org.xml.sax.XMLReader中的方法做下補充說明:除了前面介紹的一系列事件處理器注冊方法set/getXXXX()外,還有個重要的函數(shù):parse(InputSource input)–Parse an XML document,開始解析一個XML文檔。

按照應(yīng)用程序開發(fā)的流程,簡要介紹下SAX的使用方法

  1. 首先,編寫了解XML文檔的結(jié)構(gòu),按照XML文檔的結(jié)構(gòu),編寫具體的數(shù)據(jù)結(jié)構(gòu),類似于:XXXXList,XXXXItem,最好與XML的文檔保持一致。
  2. 其次,開始實現(xiàn)事件處理對象,Android SDK為我們提供了DefaultHandler,其繼承了ContentHandler 、DTDHandler、 EntityResolver、 ErrorHandler的所有接口。我們在DefaultHandler的基礎(chǔ)上,按照需求實現(xiàn)ContentHanlder的所有接口,這里需要注意2個方面的問題:
    1. 事件處理的順序,處理時間的位置:一般在startDocument()初始化工作,在endDocument()中收尾的處理工作;startElement()—characters()—endDocument()是一個XML節(jié)點讀取的過程,startElement()用來初始判斷,characters()獲取節(jié)點的字符數(shù)據(jù),endDocument()將數(shù)據(jù)寫入數(shù)據(jù)結(jié)構(gòu)。
    2. 異常SAXException的處理;
  3. 然后,XML實體解析,過程如下:
    SAXParserFactory factory = SAXParserFactory.newInstance();
    SAXParser parser = factory.newSAXParser();
    XMLReader xmlreader = parser.getXMLReader();
    URL rrl = new URL(urlstring);
    InputSource is = new InputSource(url.openStream());
    Xmlreader.setContentHanlder(XXXX);
    Xmlreader.parse(is);
  4. 最后,在Activity中顯示數(shù)據(jù),一般先將XML中讀取的數(shù)據(jù),選擇合適的Adaper對數(shù)據(jù)進行封裝,然后使用ListView控件來顯示數(shù)據(jù)。

以上就是SAX讀取XML的過程,并顯示出最終的數(shù)據(jù)。以上需要注意的是SAXParserFactory ,SAXParser類來自 javax.xml.parsers包中。

總結(jié)說明

SAX讀取XML文檔的方法,占用內(nèi)存比較少,但是開發(fā)流程相比DOM就復(fù)雜多了,具體采用哪種方法比較合適,大家可以在開發(fā)的過程中來深刻體會之間的差別。

Android讀寫XML(中)


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 祁东县| 海兴县| 西乡县| 黄石市| 崇仁县| 于都县| 长垣县| 庄河市| 大理市| 芜湖市| 浦北县| 扬中市| 渭源县| 海淀区| 托里县| 福泉市| 北辰区| 比如县| 怀来县| 庄河市| 南充市| 芦山县| 靖边县| 阿坝县| 英超| 鄂州市| 南溪县| 遵化市| 长寿区| 阿瓦提县| 垫江县| 榆林市| 米脂县| 诸暨市| 寿阳县| 卢氏县| 绥棱县| 云龙县| 修武县| 罗江县| 平凉市|