首页
学习
活动
专区
圈层
工具
发布

jdom性能
EN

Stack Overflow用户
提问于 2012-04-12 11:11:24
回答 2查看 2.3K关注 0票数 2

我目前使用的是原生Java XML处理库(Xerces)。我不能使用任何sax解析器,因为我需要随机访问xml节点。当我解析XML文件时,我发现CPU使用率达到100%。有大量的小尺寸(1-10kb),我像这样处理-

代码语言:javascript
复制
while(hasFile){
processXMlfile(hasFile.next);
}

在processXMlfile()中,我正在构建解析和处理文件。

如果我转移到JDOM库,我会获得任何性能优势吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-04-12 16:39:24

瓶颈可能是XML解析,而JDOM很可能在幕后使用相同的XML解析器,因此不会有任何不同。

在解析大量小文件时,一个关键因素是避免解析器初始化成本。对所有文件重用相同的XML解析器实例。

票数 3
EN

Stack Overflow用户

发布于 2012-04-12 17:49:12

JDOM 2.0.0解决了许多性能问题。其中之一与XML文件的“紧密循环”处理直接相关。

看一看:

http://hunterhacker.github.com/jdom/jdom2/apidocs/org/jdom2/input/sax/package-summary.html

你应该这样做:

代码语言:javascript
复制
SAXBuilder saxbuilder = new SAXBuilder();
saxbuilder.setVariousConfigurations()
SAXEngine saxengine = saxbuilder.buildEnine();

while(hasfile) {
  processXML(saxengine, nextfile);
}

在JDOM2.0.0中使用SAXEngine概念将完全消除SAX解析基础设施的设置。设置时间占整个处理的很大比例。

虽然你可能仍然以100%的速度运行,但yu会发现你的吞吐量可能会增加一倍以上……

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10116891

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档