SAX |
DOM |
依序读入文件并产生相对应事件,可以处理任何大小的XML文件。 | 在内存中建立文件树,不适于处理大型的XML文件。 |
只能对文件按顺序剖析一遍,不支持对文件的随意存取 | 可以随意存取文件树的任何部分,没有次数限制 |
只能读取XML文件内容,而不能修改 | 可以随意修改文件树,从而修改了XML文件 |
开发上比较复杂,需要自己来制作事件处理器 | 易于理解,易于开发 |
可以用SAX建立自己的XML对象模型 | 已经在DOM基础之上建立了文件树 |
选择 DOM 还是选择 SAX,这取决于下面几个因素:
1.应用程序的目的:如果打算对数据作出更改并将它输出为 XML,那么在大多数情况下,DOM 是适当的选择。并不是说使用 SAX 就不能更改数据,
但是该过程要复杂得多,因为您必须对数据的一份拷贝而不是对数据本身作出更改。
2.数据容量: 对于大型文件,SAX 是更好的选择。
数据将如何使用:如果只有数据中的少量部分会被使用,那么使用 SAX 来将该部分数据提取到应用程序中可能更好。 另一方面,
如果您知道自己以后会回头引用已处理过的大量信息,那么 SAX 也许不是恰当的选择。
3.对速度的需要: SAX 实现通常要比 DOM 实现更快。
dom是w3c指定的一套规范标准,核心是按树形结构处理数据,dom解析器读入xml文件并在内存中建立一个结构一模一样的“树”,这树各节点和xml各标记对应,通过操纵此“树”来处理xml中的文件。xml文件很大时,建立的“树”也会大,所以会大量占用内存。
sax解析器占内存少,效率高。
sax解析器核心是事件处理机制。例如解析器发现一个标记的开始标记时,将所发现的数据会封装为一个标记开始事件,并把这个报告给事件处理器,事件处理器再调用方法(startElement)处理发现的数据。事件处理器可以自己编写也可以从父类继承。
sax解析器占内存少,效率高。
sax解析器核心是事件处理机制。例如解析器发现一个标记的开始标记时,将所发现的数据会封装为一个标记开始事件,并把这个报告给事件处理器,事件处理器再调用方法(startElement)处理发现的数据。事件处理器可以自己编写也可以从父类继承。
Dom解析XML
public class DomDemo {
//
public static void main(String[] args) throws Exception {
public static void main(String[] args) throws Exception {
// 1.创建一个用来创建DOM解析器对象的工厂
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
// 2.工厂创建解析器对象
DocumentBuilder dbuilder = factory.newDocumentBuilder();
// 3.解析指定的文件,得到Document对象,即文档对象
Document doc = dbuilder.parse("F:\\abc\\Students.xml");
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
// 2.工厂创建解析器对象
DocumentBuilder dbuilder = factory.newDocumentBuilder();
// 3.解析指定的文件,得到Document对象,即文档对象
Document doc = dbuilder.parse("F:\\abc\\Students.xml");
// 获得第一个节点
Node node = doc.getFirstChild();
System.out.println(node.getNodeName());
Node node = doc.getFirstChild();
System.out.println(node.getNodeName());
// 获得该节点的所有子节点
NodeList list = node.getChildNodes();
// 遍历节点队列,获得所有子节点
for (int i = 0; i < list.getLength(); i++) {
Node n = list.item(i);
if (n instanceof Element) {
System.out.println(n.getNodeName());
}
}
NodeList list = node.getChildNodes();
// 遍历节点队列,获得所有子节点
for (int i = 0; i < list.getLength(); i++) {
Node n = list.item(i);
if (n instanceof Element) {
System.out.println(n.getNodeName());
}
}
}
}
Dom解析XML
public class DomDemo {
//
public static void main(String[] args) throws Exception {
public static void main(String[] args) throws Exception {
// 1.创建一个用来创建DOM解析器对象的工厂
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
// 2.工厂创建解析器对象
DocumentBuilder dbuilder = factory.newDocumentBuilder();
// 3.解析指定的文件,得到Document对象,即文档对象
Document doc = dbuilder.parse("F:\\abc\\Students.xml");
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
// 2.工厂创建解析器对象
DocumentBuilder dbuilder = factory.newDocumentBuilder();
// 3.解析指定的文件,得到Document对象,即文档对象
Document doc = dbuilder.parse("F:\\abc\\Students.xml");
// 获得第一个节点
Node node = doc.getFirstChild();
System.out.println(node.getNodeName());
Node node = doc.getFirstChild();
System.out.println(node.getNodeName());
// 获得该节点的所有子节点
NodeList list = node.getChildNodes();
// 遍历节点队列,获得所有子节点
for (int i = 0; i < list.getLength(); i++) {
Node n = list.item(i);
if (n instanceof Element) {
System.out.println(n.getNodeName());
}
}
NodeList list = node.getChildNodes();
// 遍历节点队列,获得所有子节点
for (int i = 0; i < list.getLength(); i++) {
Node n = list.item(i);
if (n instanceof Element) {
System.out.println(n.getNodeName());
}
}
}
}
相关推荐
setting.xml文件,修改Maven仓库指向至阿里仓
基于java的玉安农副产品销售系统的开题报告
dev-c++ 6.3版本
基于java的项目监管系统开题报告
基于springboot多彩吉安红色旅游网站源码数据库文档.zip
毕业设计&课设_基于 AFLFast 改进能量分配策略的毕业设计项目,含 Mix Schedule策略设计及测试结果分析.zip
基于springboot办公用品管理系统源码数据库文档.zip
C++调用qml对象Demo
非常漂亮的类Web界面的Delphi设计54ed7-main.zip
VB SQL车辆管理系统是一款基于Visual Basic(VB)编程语言和SQL数据库开发的综合车辆管理工具。该系统集成了车辆信息管理、驾驶员信息管理、车辆调度、维修记录、数据存储与检索、报告生成以及安全权限管理等多个核心功能模块。 源代码部分提供了详细的开发流程和实现方法,涵盖了从数据库设计、界面设计到事件驱动编程、数据访问技术和错误处理等关键技术点。通过该系统,用户可以方便地录入、查询、修改和删除车辆及驾驶员信息,实现车辆信息的实时更新和跟踪。同时,系统还支持生成各类车辆管理相关的报告,帮助用户更好地掌握车辆运营情况。 系统部分则采用了直观易用的用户界面设计,使得用户能够轻松上手并快速完成车辆管理工作。系统还具备强大的数据处理能力和安全性,通过数据备份和系统升级优化等功能,确保数据的完整性和系统的稳定运行。 总体而言,VB SQL车辆管理系统是一款功能全面、易于操作且安全可靠的车辆管理工具,适用于企业和个人进行日常车辆运营和管理。无论是车辆信息的录入、查询还是报告生成,该系统都能够提供高效、便捷的服务,是车辆管理工作的理想选择。
AutoSAR基础学习资源
基于springboot英语学习平台源码数据库文档.zip
数据集,深度学习,密封数据集,马体态数据集
基于java的数字家庭网站开题报告
podman使用国内源镜像加速器
基于springboot+web的留守儿童网站源码数据库文档.zip
基于springboot的智能宾馆预定系统源码数据库文档.zip
GetQzonehistory-main.zip
环境说明:开发语言:Java 框架:springboot JDK版本:JDK1.8 服务器:tomcat7 数据库:mysql 5.7 数据库工具:Navicat 开发软件:eclipse/myeclipse/idea Maven包:Maven 浏览器:谷歌浏览器。 项目经过测试均可完美运行
内容概要:本文档详细介绍了QST公司生产的QMI8A01型号的6轴惯性测量单元的数据表及性能参数。主要内容包括设备特性、操作模式、接口标准(SPI、I2C与I3C),以及各种运动检测原理和技术规格。文中还提到了设备的工作温度范围宽广,内置的大容量FIFO可用于缓冲传感器数据,减少系统功耗。此外,对于器件的安装焊接指导亦有详细介绍。 适合人群:电子工程技术人员、嵌入式开发人员、硬件设计师等。 使用场景及目标:适用于需要精准测量物体空间位置变化的应用场合,如消费电子产品、智能穿戴设备、工业自动化等领域。帮助工程师快速掌握该款IMU的技术要点和应用场景。 其他说明:文档提供了详细的电气连接图表、封装尺寸图解等资料,方便用户进行电路板的设计制作。同时针对特定应用提出了一些优化建议。