jaxp解析XML之SAX解析

SAX解析原理
是事件驱动的XML解析处理方法,是基于事件驱动的。
ContentHandler文档处理器类中
常用事件方法
startDocument("");文档开始事件时调用
endDocument("");文档结束事件时调用
startElement("")回调在每次SAX解析器遇到元素的起始标记时被调用
characters("")回调为字符数据时所调用
endElement("")回调为元素的结束标记所调用
DefaultHandLer类中来实现所有这些回调,并提供所有回调方法默认的空实现,是空实现不是抽象方法,空实现的好处需要用到哪个就子类复写哪个方法。

SAXPareser
不同于DOM的解析器会返回一个document文档对象,加载整个XML文档,该解析器在接收文档时同时接收一个ContentHandler文档处理器,通过文档处理器的事件方法来实时对XML文档进行处理。
从这里可以看出推模式的作用特征,由解析器内部主导事件方法调用

实例

public class SAXTest{
  public static void main(String[]args){
    SAXParserFactory factory=SAXParserFactory.newInstance();//创建解析工厂
    SAXParser parser=factory.newSAXParser();//获取解析器对象
    MyHandler handler=new MyHandler();//获取文档处理器对象
    parser.parse(".xml",handler);//进行解析,在解析过程中会自动调用事件方法	
  }
}
class MyHandLer extends DefaultHandler{
//此处为了说明只复写了一个方法,自动调用方法自动解析将对应参数对象传递进去,通过对对象进行操作xml
  public void startDocument(String uri,String localName,String aName,Attributes attributes)throws SAXException{

  }
}

  

原文地址:https://www.cnblogs.com/ss561/p/4612147.html