sax解析XML原理,基于事件驱动机制,在文档开头、标签开头等地方触发事件,解析速度快、占用内存少,但使用比较复杂,比较适合移动终端的使用方式
解析步骤:
①创建XML解析处理器。 SAXParserFactory factory = SAXParserFactory.newInstance();
②创建SAX解析器。 SAXParser parser = factory.newSAXParser();
③将XML解析处理器分配给解析器。 parser.parse(file, handler);
④对文档进行解析,将每个事件发送给处理器。
handler是自己创建类的对象如下所示:
public class MyHandler extends DefaultHandler {
List<Person> list;
Person p;
String tagName;
public MyHandler(){
}
public List<Person> getList()
{
return list;
}
//读取标签中的字符信息时调用
@Override
public void characters(char[] ch, int start, int length)
throws SAXException {
// TODO Auto-generated method stub
Log.i("my", "characters");
if(p != null && tagName != null){
String va = new String(ch,start,length);
if(tagName.equals("name")){
p.setName(va);
}else if(tagName.equals("age")){
p.setAge(Integer.parseInt(va));
}
}
}
//每个标签时调用
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
// TODO Auto-generated method stub
super.endElement(uri, localName, qName);
Log.i("my", "endElement");
if(this.tagName.equals("person")){
list.add(p);
p = null;
}
tagName = null;
}
//开始文档时,第一个标签时调用
@Override
public void startDocument() throws SAXException {
// TODO Auto-generated method stub
super.startDocument();
Log.i("my", "startDocument");
list = new ArrayList<Person>();
}
//标签开始时调用
@Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
// TODO Auto-generated method stub
super.startElement(uri, localName, qName, attributes);
Log.i("my", "startElement");
this.tagName = localName;
if(tagName.equals("person")){ //把Id打进去
p = new Person();
p.setId(Integer.parseInt(attributes.getValue(0)));
}
}
}