【java 面试题】XML

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());

}

}

}