一、DOM (文檔對象模型)
       為 XML 文檔的已解析版本定義了一組接口。解析器讀入整個文檔,然后構建一個駐留內存的樹結構,然后代碼就可以使用 DOM 接口來操作這個樹結構。
        優點:整個文檔樹在內存中,便于操作;支持刪除、修改、重新排列等多種功能;
        缺點:將整個文檔調入內存(包括無用的節點),浪費時間和空間;
       使用場合:一旦解析了文檔還需多次訪問這些數據;
                           硬件資源充足(內存、CPU)

二、SAX
       為解決DOM的問題,出現了SAX。
       SAX ,事件驅動。當解析器發現元素開始、元素結束、文本、文檔的開始或結束等時,發送事件,程序員編寫響應這些事件的代碼,保存數據。
       優點:不用事先調入整個文檔,占用資源少;
                    SAX解析器代碼比DOM解析器代碼小,適于Applet,下載
       缺點:不是持久的;事件過后,若沒保存數據,那么數據就丟了;
                    無狀態性;從事件中只能得到文本,但不知該文本屬于哪個元素;
      使用場合:Applet;
                          只需XML文檔的少量內容,很少回頭訪問;
                          機器內存少;

三、JDOM 
       為減少DOM、SAX的編碼量,出現了JDOM;
        優點:20-80原則,極大減少了代碼量
       使用場合:要實現的功能簡單,如解析、創建等
                           Java程序
        但在底層,JDOM還是使用SAX(最常用)、DOM、Xanan

四、JAPX
        為多個XML解析器提供了統一編程接口
        更換解析器,不用更改代碼
        使用場合:若不用Jdom,一般建議使用JAPX,將代碼與各種解析器的實現細節隔離。