解决方案 »
- 关于XML
- 求教各位ibatis"数据大小超出此类型的最大值"的异常,内详~
- swing中嵌入网页的问题
- 高分求Hibernate 多对多查询思路或语句..
- JSF/Struts两个框架共存在一个项目中
- struts2的action返回字符串跳转页面时报错,什么情况~~~
- 请给我一个对EJB的性能问题的正确认识.
- struts模式中又是这个错误信息:The server encountered an unexpected condition which prevented it from fulfilling the request.
- 高分请教:jms中接收消息时是怎样触发onmessage 事件的
- sql面试题,求大神解答
- 救命啊,我做项目遇到困难了,是一个spring注入的问题
- 请推荐一个开源的邮件服务,类似james的,谢谢
如果文件比较大的话sax可能比较好.
dom占内存应该比较大.
SAX是Simple API for XML的缩写,它并不是由W3C官方所提出的标准,可以说是“民间”的事实标准。实际上,它是一种社区性质的讨论产物。虽然如此,在XML中对SAX的应用丝毫不比DOM少,几乎所有的XML解析器都会支持它。与DOM 比较而言,SAX是一种轻量型的方法。我们知道,在处理DOM的时候,我们需要读入整个的XML文档,然后在内存中创建DOM树,生成DOM树上的每个 Node对象。当文档比较小的时候,这不会造成什么问题,但是一旦文档大起来,处理DOM就会变得相当费时费力。特别是其对于内存的需求,也将是成倍的增长,以至于在某些应用中使用DOM是一件很不划算的事(比如在applet中)。这时候,一个较好的替代解决方法就是SAX。SAX在概念上与DOM完全不同。首先,不同于DOM的文档驱动,它是事件驱动的,也就是说,它并不需要读入整个文档,而文档的读入过程也就是SAX的解析过程。所谓事件驱动,是指一种基于回调(callback)机制的程序运行方法。(如果你对Java新的代理事件模型比较清楚的话,就会很容易理解这种机制了)
在XMLReader 接受XML文档,在读入XML文档的过程中就进行解析,也就是说读入文档的过程和解析的过程是同时进行的,这和DOM区别很大。解析开始之前,需要向 XMLReader注册一个ContentHandler,也就是相当于一个事件监听器,在ContentHandler中定义了很多方法,比如 startDocument(),它定制了当在解析过程中,遇到文档开始时应该处理的事情。当XMLReader读到合适的内容,就会抛出相应的事件,并把这个事件的处理权代理给ContentHandler,调用其相应的方法进行响应。