2使用DOM解析XML时,首先将XML文档加载到内存当中,然后可以通过随机的方式访问内存中的DOM树;SAX是基于事件而且是顺序执行的,一旦经过了某个元素,我们就没有办法再去访问它了,SAX不必事先将整个XML文档加载到内存当中,因此它占据内存要比DOM小,对于大型的XML文档来说,通常会使用SAX而不是DOM进行解析。
3. SAX也是使用的观察者模式(类似于GUI中的事件)。
public static void main(String[] args) throws ParserConfigurationException,SAXException,Exception { //step1:获得工厂实例 SAXParserFactory factory=SAXParserFactory.newInstance(); //step2:获得解析器实例 SAXParser parser=factory.newSAXParser(); //step3:解析 parser.parse(new File("E:\\我的文档\\开发相关\\JAVA视频2\\Java培训视频教程\\4.Java xml培训视频\\Lesson 3 code\\code\\student.xml"),new myHandler()); }
class myHandler extends DefaultHandler { private Stack<String> stack=new Stack<String>(); private String name; private String age; private String gender; @Override public void startDocument() throws SAXException { // TODO Auto-generated method stub System.out.println("开始解析文档"); } @Override public void startElement(String uri,String localName,String qName,Attributes attributes) throws SAXException { stack.push(qName); for (int i=0;i<attributes.getLength();i++) { String name =attributes.getQName(i); String value=attributes.getValue(i); System.out.println(name+" = "+value); } } @Override public void characters(char[] ch,int start,int length) throws SAXException { String tagString =stack.peek(); if ("姓名".equals(tagString)) { name=new String (ch,start,length); } else if ("年龄".equals(tagString)) { age=new String (ch,length); } else if ("性别".equals(tagString)) { gender=new String (ch,length); } } @Override public void endElement(String uri,String qName) throws SAXException { stack.pop(); if ("学生".equals(qName)) { System.out.println(name); System.out.println(age); System.out.println(gender); } } @Override public void endDocument() throws SAXException { System.out.println("解析文档完毕"); } }