<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > SAX PULL DOCUMENT解析XML總結

          SAX PULL DOCUMENT解析XML總結

          作者: 時間:2016-09-12 來源:網絡 收藏

          一、SAX

          本文引用地址:http://www.ex-cimer.com/article/201609/303742.htm

          1、繼承DefaultHandler類,重寫startDocument、startElement、character、endElement、endDocument方法,startDocument在讀取時調用,可寫一些實例化列表等;startElement在讀取每個標簽時調用,通過判斷歷史標簽需要是否為需要獲取的值的頭;characters用來讀取標簽中的值;endElement讀取標簽的結束,用來保存characters獲取的值;endDocument一般不做處理。

          2、調用,用SAXParser或者XMLReader來

          SAXParser

          SAXHandlerParseService saxForHandler = newSAXHandlerParseService();
          SAXParserFactory spf = SAXParserFactory.newInstance();
          SAXParser saxParse = spf.newSAXParser();
          saxParse.parse(input, saxForHandler);
          ListMapString, Object>> userList = saxForHandler.getUser();

          XMLReader解析

          SAXHandlerParseService saxForHandler = new SAXHandlerParseService();

          SAXParserFactory spf = SAXParserFactory.newInstance();

          SAXParser saxParse = spf.newSAXParser();

          // 為xmlReader設置內容處理器

          XMLReader reader = saxParse.getXMLReader();

          reader.setContentHandler(saxForHandler);

          // 開始賦值

          reader.parse(new InputSource(new StringReader(xml)));

          List> userList = saxForHandler.getUser();

          在解析時,一定要小心,不要忽略空白的地方,Sax解析器會把它認為是一個TextNod

          二、PULL解析

          與SAX類似,同樣有START_DOCUMENT、START_ELEMENT、CHARACTERS、END_ELEMENT、END_DOCUMENT

          1、實例化XmlPullParser解析器,設置輸入編碼(setInput),獲得事件類型(getEventType),用SAX相同的處理進行,next()方法往下繼續(xù)讀取

          三、DOCUMENT解析

          1、實例化DocumentBuilderFactory,代碼如下:

          DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();

          DocumentBuilder builder = factory.newDocumentBuilder();

          Document document = builder.parse(input);

          Element root = document.getDocumentElement();

          2、跟xml傳入的數(shù)據結構進行處理

          3、返回需要的列表值即可

          工程下載:ParseTest.rar

          四、三者區(qū)別

          DOM:

          解析器讀入整個文檔,然后構建一個駐留內存的樹結構,然后代碼就可以使用 DOM 接口來操作這個樹結構。

          優(yōu)點:整個文檔樹在內存中,便于操作;支持刪除、修改、重新排列等多種功能;

          缺點:將整個文檔調入內存(包括無用的節(jié)點),浪費時間和空間;

          使用場合:一旦解析了文檔還需多次訪問這些數(shù)據;硬件資源充足(內存、CPU)

          SAX/PULL:

          事件驅動。當解析器發(fā)現(xiàn)元素開始、元素結束、文本、文檔的開始或結束等時,發(fā)送事件,程序員編寫響應這些事件的代碼,保存數(shù)據。

          優(yōu)點:不用事先調入整個文檔,占用資源少

          缺點:不是持久的;事件過后,若沒保存數(shù)據,那么數(shù)據就丟了;無狀態(tài)性;從事件中只能得到文本,但不知該文本屬于哪個元素;

          使用場合:只需XML文檔的少量內容,很少回頭訪問;一次性讀取;機器內存少;

          注意:SAX 解析器不創(chuàng)建任何對象。



          關鍵詞: 解析 XML總結

          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();