SAX和DOM区别
程序员文章站
2022-05-22 16:42:11
...
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());
}
}
}
}
上一篇: IE6双倍内外边距解决方案
下一篇: DOM替换节点