真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

AndroidSAX解析器怎么實現(xiàn)

本篇內(nèi)容介紹了“Android SAX解析器怎么實現(xiàn)”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

和林格爾網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián),和林格爾網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為和林格爾千余家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)網(wǎng)站制作要多少錢,請找那個售后服務(wù)好的和林格爾做網(wǎng)站的公司定做!

de >RssHandlerde > 類擴展了 de  >org.xml.sax.helpers.DefaultHandlerde > 類。該類為 SAX  解析器生成的事件所對應(yīng)的所有方法都提供了一個默認的非操作實現(xiàn)。這允許子類根據(jù)需要僅覆蓋一些方法。de >RssHandlerde >  提供了一個額外的 API,即 de >getMessagesde >。它返回處理程序在從 SAX 解析器接收事件時所收集的 de  >Messagede > 對象列表。它有另外兩個內(nèi)部變量,de >currentMessagede > 針對被解析的  de >Messagede > 實例,以及名稱為 de >builderde > 的 de  >StringBuilderde > 變量,用于存儲文本節(jié)點中的字符數(shù)據(jù)。解析器將相應(yīng)事件發(fā)送給處理程序時會調(diào)用 de  >startDocumentde > 方法,這兩個變量的初始化操作就是在此時完成。

查看de >startElementde > 方法。在XML文檔中每次遇到開始標記時都會調(diào)用它。您只關(guān)心該標記何時為 de  >ITEMde > 標記。對于這種情況,您將創(chuàng)建一個新的 de >Messagede >?,F(xiàn)在來看 de  >charactersde > 方法。遇到文本節(jié)點中的字符數(shù)據(jù)時便會調(diào)用此方法。數(shù)據(jù)只是被添加到 de >builderde  > 變量中。***,我們來看 de >endElementde > 方法。遇到結(jié)束標記時會調(diào)用此方法。對于與某 de  >Messagede > 屬性相對應(yīng)的標記,如 de >TITLEde > 和 de >LINKde  >,則使用 de >builderde > 變量中的數(shù)據(jù)在 de >currentMessagede >  上設(shè)置適當?shù)膶傩浴H绻Y(jié)束標記是一個 de >ITEMde >,則 de >currentMessagede >  將被添加到 Messages 列表中。所有這些都是非常典型的 SAX 解析;此處的一切都不是 Android 所特有的。因此,如果您知道如何編寫  Java SAX 解析器,則應(yīng)該知道如何編寫 Android SAX 解析器。但是,android sdk 確實在 SAX 上添加了一些便捷的特性。

Android SAX 解析器

java代碼:

public class AndroidSaxFeedParser extends BaseFeedParser { public AndroidSaxFeedParser(String feedUrl) { super(feedUrl); } public List< Message > parse() { RssHandler handler = new RssHandler(); try { Xml.parse(this.getInputStream(), Xml.Encoding.UTF_8, handler); } catch (Exception e) { throw new RuntimeException(e); } return handler.getMessages(); } }

注意,這個類仍然使用了一個標準的 SAX 處理程序,因此您僅僅重用了所示的 de >RssHandlerde >。能夠重用 SAX  處理程序是非常不錯的,但其代碼稍微有些復(fù)雜。您可以想像,如果需要解析一個更加復(fù)雜的 XML 文檔,則處理程序可能會帶來各種各樣的  bug。舉例來說,回頭看看 de >endElementde > 方法。注意,在嘗試設(shè)置屬性之前,它檢查了 de  >currentMessagede > 是否為 null?,F(xiàn)在,再回頭看看示例 XML。 注意,de >ITEMde >  標記外部有一些 de >TITLEde > 和 de >LINKde > 標記。這就是使用 null  檢查的原因。否則,每一個 de >TITLEde > 標記 會導(dǎo)致一個 de >NullPointerExceptionde  >。Android 提供了自己獨有的 SAX API,它排除了您編寫自己的 SAX 處理程序的需要。

經(jīng)過簡化的 Android SAX 解析器

java代碼:

public class AndroidSaxFeedParser extends BaseFeedParser { public AndroidSaxFeedParser(String feedUrl) { super(feedUrl); } public List< Message > parse() { final Message currentMessage = new Message(); RootElement root = new RootElement("rss"); final List< Message > messages = new ArrayList< Message >(); Element channel = root.getChild("channel"); Element item = channel.getChild(ITEM); item.setEndElementListener(new EndElementListener(){ public void end() { messages.add(currentMessage.copy()); } }); item.getChild(TITLE).setEndTextElementListener(new EndTextElementListener(){ public void end(String body) { currentMessage.setTitle(body); } }); item.getChild(LINK).setEndTextElementListener(new EndTextElementListener(){ public void end(String body) { currentMessage.setLink(body); } }); item.getChild(DESCRIPTION).setEndTextElementListener(new EndTextElementListener(){ public void end(String body) { currentMessage.setDescription(body); } }); item.getChild(PUB_DATE).setEndTextElementListener(new EndTextElementListener(){ public void end(String body) { currentMessage.setDate(body); } }); try { Xml.parse(this.getInputStream(), Xml.Encoding.UTF_8,root.getContentHandler()); } catch (Exception e) { throw new RuntimeException(e); } return messages; } }

“Android SAX解析器怎么實現(xiàn)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!


新聞標題:AndroidSAX解析器怎么實現(xiàn)
文章出自:http://weahome.cn/article/jihjcj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部