標籤:
XML現在已經成為一種通用的資料交換格式,它的平台無關性,語言無關性,系統無關性,給Data Integration與互動帶來了極大的方便。對於XML本身的文法知識與技術細節,需要閱讀相關的技術文獻,這裡麵包括的內容有DOM(Document Object Model),DTD(Document Type Definition),SAX(Simple API for XML),XSD(Xml Schema Definition),XSLT(Extensible Stylesheet Language Transformations。
package com.alisoft.facepay.framework.bean;
/**
*
* @author hongliang.dinghl
* 定義XML文檔建立與解析的介面
*/
public interface XmlDocument {
/**
* 建立XML文檔
* @param fileName 檔案全路徑名稱
*/
public void createXml(String fileName);
/**
* 解析XML文檔
* @param fileName 檔案全路徑名稱
*/
public void parserXml(String fileName);
}
XML在不同的語言裡解析方式都是一樣的,只不過實現的文法不同而已。基本的解析方式有兩種,一種叫SAX,另一種叫DOM。SAX是基於事件流的解析,DOM是基於XML文檔樹結構的解析。假設我們XML的內容和結構如下:
<?xml version="1.0" encoding="UTF-8"?>
<employees>
<employee>
<name>ddviplinux</name>
<sex>m</sex>
<age>30</age>
</employee>
</employees>
1.DOM產生和解析XML文檔
為XML文檔的已解析版本定義了一組介面。解析器讀入整個文檔,然後構建一個駐留記憶體的樹結構,然後代碼就可以使用 DOM 介面來操作這個樹結構。優點:整個文檔樹在記憶體中,便於操作;支援刪除、修改、重新排列等多種功能;缺點:將整個文檔調入記憶體(包括無用的節點),浪費時間和空間;使用場合:一旦解析了文檔還需多次訪問這些資料;硬體資源充足(記憶體、CPU)。
2.SAX產生和解析XML文檔
為解決DOM的問題,出現了SAX。SAX ,事件驅動。當解析器發現元素開始、元素結束、文本、文檔的開始或結束等時,發送事件,程式員編寫響應這些事件的代碼,儲存資料。優點:不用事先調入整個文檔,佔用資源少;SAX解析器代碼比DOM解析器代碼小,適於Applet,下載。缺點:不是持久的;事件過後,若沒儲存資料,那麼資料就丟了;無狀態性;從事件中只能得到文本,但不知該文本屬於哪個元素;使用場合:Applet;只需XML文檔的少量內容,很少回頭訪問;機器記憶體少。
3.DOM4J產生和解析XML文檔
DOM4J 是一個非常非常優秀的Java XML API,具有效能優異、功能強大和極端易用使用的特點,同時它也是一個開放原始碼的軟體。如今你可以看到越來越多的 Java 軟體都在使用 DOM4J 來讀寫 XML,特別值得一提的是連 Sun 的 JAXM 也在用 DOM4J托福答案
4.JDOM產生和解析XML
為減少DOM、SAX的編碼量,出現了JDOM;優點:20-80原則,極大減少了代碼量。使用場合:要實現的功能簡單,如解析、建立等,但在底層,JDOM還是使用SAX(最常用)、DOM、Xanan文檔。
Java中解析XML的四種方法