- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Java中四种XML解析技术详解
Java中四种XML 解析技术
在平时工作中,难免会遇到把 XML 作为数据存储格式。面对目前种类繁多的解决方
案,哪个最适合我们呢?在这篇文章中,我对这四种主流方案做一个不完全评测,仅仅针对
遍历 XML 这块来测试,因为遍历 XML 是工作中使用最多的。
XML 文件格式如下:
<?xml version=1.0encoding=GB2312?>
<RESULT>
<VALUE>
<NO>A1234</NO>
<ADDR>四川省XX县XX镇XX路X段XX号</ADDR>
</VALUE>
<VALUE>
<NO>B1234</NO>
<ADDR>四川省XX市XX乡XX村XX组</ADDR>
</VALUE>
</RESULT>
测试方法:
采 用 JSP 端 调 用 Bean ( 至 于 为 什 么 采 用 JSP 来 调 用 , 请 参 考 :
/rosen/archive/2004/10/15/138324.aspx),让每一种方案分别解析10K、100K、
1000K、10000K的 XML 文件,计算其消耗时间(单位:毫秒)。
JSP 文件:
<%@ page contentType=text/html; charset=gb2312%>
<%@ page import=com.test.*%>
<html>
<body>
<%
Stringargs[]={};
MyXMLReader.main(args);
%>
</body>
</html>
首先出场的是 DOM(JAXPCrimson 解析器)
DOM 是用与平台和语言无关的方式表示 XML 文档的官方 W3C 标准。DOM 是以层
次结构组织的节点或信息片断的集合。这个层次结构允许开发人员在树中寻找特定信息。分
析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作。由于它是基于信息
层次的,因而 DOM 被认为是基于树或基于对象的。DOM 以及广义的基于树的处理具有
几个优点。首先,由于树在内存中是持久的,因此可以修改它以便应用程序能对数据和结构
作出更改。它还可以在任何时候在树中上下导航,而不是像 SAX 那样是一次性的处理。
DOM 使用起来也要简单得多。
另一方面,对于特别大的文档,解析和加载整个文档可能很慢且很耗资源,因此使用其
他手段来处理这样的数据会更好。这些基于事件的模型,比如 SAX。
Bean文件:
packagecom.test;
importjava.io.*;
importjava.util.*;
importorg.w3c.dom.*;
importjavax.xml.parsers.*;
publicclass MyXMLReader{
publicstatic voidmain(Stringarge[]){
longlasting =System.currentTimeMillis();
try{
Filef=newFile(data_10k.xml);
DocumentBuilderFactoryfactory=DocumentBuilderFactory.newInstance();
DocumentBuilderbuilder=factory.newDocumentBuilder();
Document doc=builder.parse(f);
NodeList nl=doc.getElementsByTagName(VALUE);
for(int i=0;i<nl.getLength();i++){
System.out.print( 车 牌 号 码 : +
doc.getElementsByTagName(NO).item(i).getFirstChild().getNodeValue());
System.out.println( 车 主 地 址 :
您可能关注的文档
最近下载
- 飞利浦HTS5540 93家庭影院说明书.pdf
- 面馆促销聚人气方案.docx VIP
- 《中国文化概况》带翻译版.pdf VIP
- 人教版数学六年级下册比例(课件).pptx VIP
- 旧版现代西班牙语第1册 课文+答案.pdf VIP
- 2023年贵州贵州高速公路集团有限公司招聘笔试真题.docx VIP
- 变电站运行中倒闸防误操作及对策.doc VIP
- 汽车车身制造技术 项目三 车身焊装工艺.ppt VIP
- Chapter 4 Lending a hand (课件)-2024-2025学年新思维小学英语5A.pptx VIP
- 2025-2030中国会展行业市场发展现状分析及发展趋势与投资前景研究报告.docx
文档评论(0)