在使用 DOM 解析 XML 文档时,需要读取整个 XML 文档,在内存中构架代表整个 DOM 树的Doucment对象,从而再对XML文档进行操作。此种情况下,如果 XML 文档特别大,就会消耗计算机的大量内存,并且容易导致内存溢出。
SAX解析允许在读取文档的时候,即对文档进行处理,而不必等到整个文档装载完才会文档进行操作。
intellij不需要进行源代码关联,会自动关联,出现问题可能的原因是导入包的错误。
主要是进行ContentHandler的编写。
用SAX进行查询xml文档:
//1.创建工厂
SAXParserFactory factory = SAXParserFactory.newInstance();
//2.用工厂创建解析器
SAXParser sp = factory.newSAXParser();
//3.利用解析器得到reader
XMLReader reader = sp.getXMLReader();
//4.在解析xml文档之前设置事件处理器
reader.setContentHandler(new MyContentHandler2());
//5.利用reader读取xml文档
reader.parse("src/book1.xml");
//获取第一个售价节点的值
class MyContentHandler2 extends DefaultHandler {
private boolean isOk = false;
private int index = 1;
@Override
public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
if (qName.equals("售价")) {
isOk = true;
}
}
@Override
public void endElement(String uri, String localName, String qName) throws SAXException {
if (qName.equals("售价")) {
isOk = false;
index++;
}
}
@Override
public void characters(char[] ch, int start, int length) throws SAXException {
if (isOk == true && index == 1){
System.out.println(new String(ch,start,length));
}
}
}
本文介绍如何使用SAX解析器在读取XML文档时即进行处理,避免加载完整文档导致的内存压力。并通过实例展示了如何编写ContentHandler以实现特定功能。
2606

被折叠的 条评论
为什么被折叠?



