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文件。
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解析方式:DOM解析器通过构建树状模型进行解析,适用于小到中型文件;SAX解析器采用事件驱动的方式,适合处理大型XML文件。文中还提供了SAX解析器的Java代码示例。
790

被折叠的 条评论
为什么被折叠?



