SAX解析允许在读取文档的时候,即对文档进行操作,而不必等到整个文档加载完了才对文档进行操作。SAX解析属于事件处理的方式,会涉及到解析器和事件处理器。
sax解析只能对xml文档进行解析的优点是:查询速度快,不会因为XML文档过大造成内存溢出。缺点是:不能做增删操作。
1. 解析器
解析器可以使用JAXP的API创建,创建出SAX解析器之后,就可以指定解析器去解析某个XML文档。
比如:获取所有的解析的内容如下
// 获取SAX的解析器工厂
SAXParserFactory factory = SAXParserFactory.newInstance();
// 获取解析器
SAXParser parser = factory.newSAXParser();
// 解析
parser.parse("xml文件路径.xml", new MyHandler2());
解析器采用SAX方式在解析某个文档时,它只要解析到XML文档的一个组成部分,都会去调用事件处理器的一个方法,解析器在调用事件处理的方法时,会把当前解析到的XML文件内容作为方法的参数传递给事件处理器。
2. 事件处理器
事件处理器由程序员编写,程序员通过事件处理器中方法的参数,就可以很轻松地得到sax解析器解析的数据,然后再对数据进行处理。要编写自己的事件处理器,一般都重写下面这三个方法。
class MyHandler extends DefaultHandler{
/**
* 只要一解析到开始标签的时候,默认调用该方法,把解析的内容赋值给参数。
*/
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
System.out.println("开始标签:"+qName);
}
/**
* 只要解析到文本的内容,默认调用该方法
*/
public void characters(char[] ch, int start, int length)
throws SAXException {
String str = new String(ch,start,length);
System.out.println(str);
}
/**
* 解析到结束标签的时候,默认调用方法,把解析的内容赋值给参数。
*/
public void endElement(String uri, String localName, String qName)
throws SAXException {
System.out.println("结束标签:"+qName);
}
}