XML(4)作业
1.dom和sax的区别
DOM解析器把XML文档转化为一个包含其内容的树,并可以对树进行遍历。用DOM解析模型的优点是编程容易,开发人员只需要调用建树的指令,然后利用 navigation APIs访问所需的树节点来完成任务。可以很容易的添加和修改树中的元素。然而由于使用 DOM解析器的时候需要处理整个XML文档,所以对性能和内存的要求比较高,尤其是遇到很大的XML文件的时候。由于它的遍历能力,DOM解析器常用于 XML文档需要频繁的改变的服务中。
SAX解析器采用了基于事件的模型,它在解析XML文档的时候可以触发一系列的事件,当发现给定的tag的时候,它可以激活一个回调方法,告诉该方法制定的标签已经找到。SAX对内存的要求通常会比较低,因为它让开发人员自己来决定所要处理的 tag.特别是当开发人员只需要处理文档中所包含的部分数据时,SAX这种扩展能力得到了更好的体现。但用SAX解析器的时候编码工作会比较困难,而且很难同时访问同一个文档中的多处不同数据。
2.使用sax解析获取第一个书名节点的值
package com.hbsi.xml;
import java.io.IOException;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.XMLReader;
import org.xml.sax.helpers.DefaultHandler;
public class Demo4 {
/**
* @param args
*/
public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException {
//创建工厂
SAXParserFactory spf = SAXParserFactory.newInstance();
//创建sax解析器
SAXParser sp = spf.newSAXParser();
//获取读取器
XMLReader xmlReader = sp.getXMLReader();
//设置事件处理器
xmlReader.setContentHandler(new BookContenHandler1());
//
xmlReader.parse("src/book.xml");
}
}
//获取所有书名节点的值
//获取第一个书名节点的值
class BookContenHandler1 extends DefaultHandler{
private String currentName;
private int findNumber=2;
private int currentNumber;
@Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
currentName=qName;
if("书名".equals(currentName)){
currentNumber++;
}
}
@Override
public void characters(char[] ch, int start, int length)
throws SAXException {
if("书名".equals(currentName) && currentNumber==findNumber){
System.out.println(new String(ch,start,length));
}
}
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
currentName=null;
}
}