【java面试题】XML

star2017 1年前 ⋅ 250 阅读
1、XML 文档定义有几种形式?它们之间有何本质区别?解析XML 文档有哪几种方式?【基础】

答:1)两种形式:dtd 以及schema;

2)本质区别:schema 本身是xml 的,可以被XML 解析器解析(这也是从DTD

上发展schema 的根本目的);

3)解析方式:有DOM,SAX,STAX 等:

DOM:处理大型文件时其性能下降的非常厉害。这个问题是由DOM 的树结

构所造成的,这种结构占用的内存较多,而且DOM 必须在解析文件之前把整个文

档装入内存,适合对XML 的随机访问;

SAX:不同于DOM,SAX 是事件驱动型的XML 解析方式。它顺序读取XML 文

件,不需要一次全部装载整个文件。当遇到像文件开头,文档结束,或者标签开

头与标签结束时,它会触发一个事件,用户通过在其回调事件中写入处理代码来

处理XML 文件,适合对XML 的顺序访问;

STAX:Streaming API for XML (StAX)。

2、你在项目中用到了xml 技术的哪些方面?如何实现的? 【中等难度】

答:用到了数据存贮,信息配置两方面。在做数据交换平台时,将不能数据源的

数据组装成XML 文件,然后将XML 文件压缩打包加密后通过网络传送给接收者,

接收解密与解压缩后再同XML 文件中还原相关信息进行处理。在做软件配置时,

利用XML 可以很方便的进行,软件的各种配置参数都存贮在XML 文件中。

3、用jdom 解析xml 文件时如何解决中文问题?如何解析? 【较难】

答:看如下代码,用编码方式加以解决

package test;

import java.io.*;

public class DOMTest{

private String inFile = "c:\people.xml";

private String outFile = "c:\people.xml";

public static void main(String args[]){

new DOMTest();

}

public DOMTest(){

try{

javax.xml.parsers.DocumentBuilder builder =

javax.xml.parsers.DocumentBuilderFactory.

newInstance().newDocumentBuilder();

org.w3c.dom.Document doc = builder.newDocument();

org.w3c.dom.Element root = doc.createElement("老师");

org.w3c.dom.Element wang = doc.createElement("王");

org.w3c.dom.Element liu = doc.createElement("刘");

wang.appendChild(doc.createTextNode("我是王老师"));

root.appendChild(wang);

doc.appendChild(root);

javax.xml.transform.Transformer transformer =

javax.xml.transform.TransformerFactory.

newInstance().newTransformer();

transformer.setOutputProperty(

javax.xml.transform.OutputKeys.ENCODING,"gb2312");

transformer.setOutputProperty(

javax.xml.transform.OutputKeys.INDENT, "yes");

transformer.transform(new

javax.xml.transform.dom.DOMSource(doc),

new javax.xml.transform.stream.StreamResult(outFile));

}catch (Exception e){

System.out.println (e.getMessage());

}

}

}

本文为博主原创文章,未经博主允许不得转载。
更多内容请访问:IT源点

相关文章推荐

全部评论: 0

    我有话说: