DOM/SAX解析XML的实现及其各自的优缺点

前两天上课学习了DOM/SAX解析XML,个人还只是把他们分开来学习,具体的区别还没有去理解
XML我觉得其实就跟HTML的格式差不多,都是标记语言,用户可以定义自己需要的标记
XML的基本格式是:
<?xml version="1.0" encoding="utf-8" ?>
<students>
<stu num='1234'>
<name>张三丰</name>
<sex>男</sex>
<cla>武当</cla>
</stu>

<stu num='12345'>
<name>杨过</name>
<sex>男</sex>
<cla>古墓派</cla>
</stu>
</students>
1、通过DOM解析XML
DOM规范核心就是树模型,是通过dom规范,能够实现dom文档和xml之间的相互转换,遍历、操作相应dom文档的内容。JXML就是通过JAVA代码来访问XML数据,实现对XML数据的增、删、改、查
DOM的结构是生成一棵树,这就产生了一些优缺点
优点是:就是整个文档都一直在内存中,我们可 以随时访问任何节点,并且对树的遍历也是比较熟悉的操作。
缺点是:耗内存,并且必须等到所有的文档都读入内存才能进行处理。
下面是DOM对XML的解析
package cjl.dom;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

/**
* Dom解析XML
*
* @author kowloon
*
*/
public class DomDemo {

//
public static void main(String[] args) throws Exception {

// 1.创建一个用来创建DOM解析器对象的工厂
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
// 2.工厂创建解析器对象
DocumentBuilder dbuilder = factory.newDocumentBuilder();
// 解析指定的文件,得到Document对象,即文档对象
Document doc = dbuilder.parse("F:\\abc\\Students.xml");

// 获得第一个节点
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());
}
}

}

}
2、SAX解析XML
SAX的工作原理简单地说就是对文档进行顺序扫描,当扫描到文档开始与结束、元素开始与结束、文档(document)结束等地方时通知事件处理函数,由事件处理函数做相应动作,然后继续同样的扫描,直至文档结束。
而SAX相比于DOM的优点是:
解析速度快,SAX解析器是对文档的解析过程是一种边解析边执行的过程,
内存消耗少,SAX解析器对文档的解析过程中,无需把整个文档都加载到内存中
ContentHandler对象可以是多个:使用SAX解析器时,可以注册多个ContentHandler对象,并行接收事件。
SAX的缺点是:
必须实现事件处理程序
不能随机访问:SAX解析器对文档的解析是顺序进行的
不能修改文档:使用SAX对文档进行解析,只能访问文档内容,无法做到向文档中添加节点,更不能删除和修改文档中的内容。

下面就是SAX解析XML
package wh;

import java.io.File;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;

import org.w3c.dom.Document;

public class SAXDemo {
public static void main(String[] args) throws Exception {
//查找xml文件的路径
File f = new File("F:\\aaa\\Students.xml");

// 创建解析器工厂对象,使用SAX解析XML文件
SAXParserFactory factory = SAXParserFactory.newInstance();
// 创建一个解析器对象,
SAXParser sax = factory.newSAXParser();
// 创建事件处理器对象,对sax对象进行处理,
MyDefaultHandler handler = new MyDefaultHandler();

//解析xml文件
sax.parse(f, handler);

}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值