SAX提供了一種對XML文檔進行順序訪問的模式,這是一種快速讀XML數據的方式。SAX接口是事件驅動的,當使用SAX分析器對XML文檔進行分析時,就會觸發一系列事件,並激活相應的事件處理函數,從而完成對XML文檔的訪問。SAX處理XML的方式與DOM不同。SAX解析器不是將DOM樹解析和表現爲輸出,它是基於事件的,所以在XML被解析時,事件被髮送給引擎。SAX可以在文檔的開始接收事件,也可以接收文檔中的元素。使用這些事件可以構建一種結構。因爲SAX沒有把XML文檔完全地加載到內存中,所以需要的系統資源較少,是一個分析大型XML文檔的高效API。缺點是編寫SAX比編寫DOM複雜,這因爲首先必須實現通知接口並維護狀態,其次SAX不允許對文檔進行隨機訪問,也沒有提供像DOM那樣的修改功能。
SAX:
Simple Api for XML (xml簡單處理API),提供了一種基於事件的XML的解析方式
多用於快速讀取XML文檔
基於事件驅動,在內存中並不會加載整個文檔,效率要高(解析大型XML文檔)
不能重複讀取 順序讀取模式
1.得到工廠實例
SAXParserFactory actory=SAXParserFactory.newInstance();
2.由工廠實例 得到 解析器
SAXParser parser=factory.newSAXParser();
3.解析器 parse (File f,MyHandler extends DefaultHandler dh)
Class MyHandler extends DefaultHandler{
public void …
}
SAX解析實例
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import java.io.*;
import org.xml.sax.helpers.DefaultHandler;
import org.xml.sax.SAXException;
import org.xml.sax.Attributes;
//使用SAX方式解析XML文檔
public class s1{
public static void main(String[] agrs)throws Exception{
//使用 SAXParser.parse() 處理文件
//1、得到工廠的實例 使用static 方法newInstance();
SAXParserFactory factory=SAXParserFactory.newInstance();
//2、使用工廠實例 得到解析器 newSAXParser();
SAXParser parser=factory.newSAXParser();
//3、使用SAXParser.parse() 處理文件
parser.parse(new File("s1.xml"),new MyHandler());
}
}
//文檔處理器 其中定義了很多回調方法 按照要求 重寫方法
class MyHandler extends DefaultHandler{
//文件開始的時候調用的方法
@Override
public void startDocument() throws SAXException{
System.out.println("文檔開始。。。");
}
//元素開始時調用的方法
@Override
public void startElement(String uri,String localName,String qName,Attributes attrs ) throws SAXException{
System.out.println("元素開始。。。");
}
@Override
public void characters(char[] ch,int start,int length)throws SAXException{
System.out.println("字符數據。。。");
}
public void endElement(String uri,String localName,String qName,Attributes attrs ) throws SAXException{
System.out.println("元素結束。。。");
}
@Override
public void endDocument() throws SAXException{
System.out.println("文檔結束。。。");
}
}