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("文档结束。。。");
}
}