Java XML解析器

来源:互联网 发布:网络综艺尺度大被叫停 编辑:程序博客网 时间:2024/06/06 17:37

目前Java XML解析器有十多种之多,解析原理有二:使用基于事件的XML简单API(Simple API for XML)称为SAX和基于树和节点的文档对象模型(Document Object Module)称为DOM。Sun公司提供了Java API for XML Parsing(JAXP)接口来使用SAX和DOM,通过JAXP,我们可以使用任何与JAXP兼容的XML解析器。但并不是所有的Java XML解析工具都实现了SUN提供的接口。DOM4J就没有遵循SUN的JAXP规范,但非常优秀。

DOM 是W3C组织推荐的处理XML的标准接口,DOM 解析器把 XML 文档转化为一个包含其内容的树,并可以对树进行遍历。用 DOM 解析模型的优点是编程容易,开发人员只需要调用建树的指令,然后利用navigation APIs访问所需的树节点来完成任务。可以很容易的添加和修改树中的元素。然而由于使用 DOM 解析器的时候需要处理整个 XML 文档,所以对性能和内存的要求比较高,尤其是遇到很大的 XML 文件的时候。由于它的遍历能力,DOM 解析器常用于 XML 文档需要频繁的改变的服务中。

SAX是由XML_DEV邮件列表的成员开发的,它不是某个官方机构的标准,也不由W3C组织或其他任何官方机构维护,但它是XML社区事实上的标准。虽然SAX只是“民间”标准,但是它在XML中的应用丝毫不比DOM少,几乎所有的XML解析器都支持它。SAX 解析器采用了基于事件的模型,它在解析 XML 文档的时候可以触发一系列的事件,当发现给定的tag的时候,它可以激活一个回调方法,告诉该方法制定的标签已经找到。SAX 对内存的要求通常会比较低,因为它让开发人员自己来决定所要处理的tag。特别是当开发人员只需要处理文档中所包含的部分数据时,SAX 这种扩展能力得到了更好的体现。但用 SAX 解析器的时候编码工作会比较困难,而且很难同时访问同一个文档中的多处不同数据。

DOM解析和SAX解析的区别

No 区 别 DOM解析 SAX解析
1 操作 将所有文件读取到内存中形成DOM树,如果文件量过大,则无法使用 顺序读入所需要的文件内容,不会一次性全部读取,不受文件大小的限制
2 访问限制 DOM树在内存中形成,可以随意存放或读取文件树的任何部分,没有次数限制 由于采用部分读取,只能对文件按顺序从头到尾读取XML文件内容,但不能修改
3 修改 可以任意修改文件树 只能读取XML文件内容,但不能修改
4 复杂度 易于理解,易于开发 开发上比较复杂,需要用户自定义事件处理器
5 对象模型 系统为使用者自动建立DOM树,XML对象模型由系统提供 对开发人员更加灵活,可以用SAX建立自己的XML对象模型

问题:使用DOM解析还是SAX解析?

回答:DOM和SAX都有自己的不同应用领域
由两者的特点可以发现两者的区别:
DOM解析适合于对文件进行修改和随机存取的操作,但是不适合于大型文件的操作;
SAX采用部分读取的方式,所以可以处理大型文件,而且只需要从文件中读取特定内容,SAX解析可以由用户自己建立自己的对象模型。

所以DOM解析适合于修改,SAX解析适合于读取大型文件,2者结合的话可以用JDOM

参考
http://dwcmayday201204063551.iteye.com/blog/1629943
http://blog.csdn.net/liuquan0071/article/details/50290629

原创粉丝点击