新聞中心

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

        SAX PULL DOCUMENT解析XML總結

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

        一、SAX

        本文引用地址:http://www.104case.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()方法往下繼續讀取

        三、DOCUMENT解析

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

        DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();

        DocumentBuilder builder = factory.newDocumentBuilder();

        Document document = builder.parse(input);

        Element root = document.getDocumentElement();

        2、跟xml傳入的數據結構進行處理

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

        工程下載:ParseTest.rar

        四、三者區別

        DOM:

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

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

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

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

        SAX/PULL:

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

        優點:不用事先調入整個文檔,占用資源少

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

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

        注意:SAX 解析器不創建任何對象。



        關鍵詞: 解析 XML總結

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 封丘县| 临洮县| 焉耆| 宝山区| 石嘴山市| 资源县| 页游| 郴州市| 望城县| 华坪县| 商洛市| 曲沃县| 玉屏| 威海市| 都江堰市| 班戈县| 台南市| 威信县| 琼海市| 浦江县| 嵊泗县| 刚察县| 长寿区| 白水县| 宣汉县| 黑龙江省| 香港| 阿图什市| 九龙坡区| 乾安县| 申扎县| 秦皇岛市| 陕西省| 鹤岗市| 邵东县| 马尔康县| 定州市| 天台县| 若尔盖县| 遵化市| 安图县|