SAX(Simple Api For XML、简单的XML解析API)。
DOM解析有一最大的问题:整个DOM的读取以及修改处理都有一个核心的实现前提:DOM树(存放在内存之中),如果说现在给了你一个1G的XML文件读取,如果使用了DOM那么基本上电脑就死机了,因为按照DOM的处理,将所有的XML文件必须读取到内存之中,才可以解析。
SAX解析的特点:采用的是顺序式的读取模式。不会一次性进行所有数据的读取控制。 因为不是一次性沾满整个的内存空间,所以SAX在解析大文件的处理上会更加的有效。
如果要想使用SAX读取,那么必须有一个专属的SAX解析器。这个解析器需要继承一个父类:org.xml.sax.helpers.DefaultHandler,在这个类中定义有如下的方法:
文档开始读取时触发
public void startDocument() throws SAXException
文档读取完毕后触发
public void endDocument() throws SAXException
元素开始
public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException
文字信息
public void characters(char[] ch, int start, int length) throws SAXException
元素结束时触发
public void endElement(String uri, String localName, String qName) throws SAXException
SAX触发器
1、 SAX解析工厂类:javax.xml.parsers.SAXParserFactory
①实例化本类对象:
public static SAXParserFactory newInstance();
②创建SAX解析工具类:
public abstract SAXParser newSAXParser() throwsParserConfigurationException,SAXException;
2、 SAX解析工具类:javax.xml.parsers.SAXParser;
解析:public void parse(InputStream is, DefaultHandler dh) throws SAXException, IOException;