SAX解析及SAX和DOM总结

DOM解析器是将XML文档解析成树状模型并放入内存来完成解析工作的,而后对文档的操作都是在这个树状模型上完成的。这样做的好处是结构清楚,操作方便。
缺点极其耗费系统资源。不适用于解析超大型的XML文件。

SAX解析器是通读整个文档,根据文档内容产生事件,而把对这些事件的处理交由事件处理器处理。SAX不需要在内存中保存整个文档,它非常节省系统资源。适用于处理超大型的XML文件。
代码示例:
//创建一个解析器工厂对象
SAXParserFactory spf = SAXParserFactory.newInstance();
    try {
         //创建sax解析器
SAXParser sp = spf.newSAXParser();

MyParseListener mpl = new MyParseListener();

XMLReader xr = sp.getXMLReader();
xr.setContentHandler(mpl);

File myfile = new File("src/com/newer/myparse/demo/student.xml");
xr.parse(new InputSource(new FileInputStream(myfile)));

List<Student> all = mpl.getAllStus();

for (Student student : all) {
System.out.println("学生姓名"+student.getStuName());
}
} catch (Exception e) {
e.printStackTrace();
}
}

你可能感兴趣的:(xml)