XML文件的读取有两种方式:1· 面向模型的DOM方式;2·面向事件的SAX方式
一:DOM方式原理:
一次性的将xml文档加入内存,在内存中形成一颗dom树,然后通过语言对树的节点进行操作。
显然这种操作查找元素快,但是一次性的将文件加载进来,要是小还行,文件大的时候会增大内存负担的,因此这种方式最好是解析小的xml文件的时候用
二:SAX 方式原理:
边读边解析,按照从做往右从上往下的顺序解析。
由于解析过的节点不能再次利用,要想使用还得再次解析,所以效率相对来说比较低,但只有事件触发了才会去读取文件,所以内存不会很大。
两种方式,各有优缺点,谁也不能代替谁,举个简单的例子吧,就像生活中的自行车无法取代汽车,汽车无法取代自行车一样,两者各有优势。根据具体需求选择。
三:demo(SAX方式读取):
1·sys-config.xml文件:(myeclipse 连接数据库的为例)
<?xml version="1.0" encoding="UTF-8"?>
<config>
<db-info>
<driver-name>oracle.jdbc.driver.OracleDriver</driver-name>
<url>jdbc:oracle:thin:@localhost:1521:orcl</url>
<user-name>drp1</user-name>
<password>drp1</password>
</db-info>
</config>
2·main方法读取xml文件代码:
import java.io.IOException;
import java.io.InputStream;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class readSysConfig {
public static void main(String[] args) throws Exception, IOException {
//readSysConfig.getInstance().getJdbcConfig();
SAXReader read = new SAXReader();//获取读取xml的对象
//获取当前线程的当前资源输入流
InputStream in =Thread.currentThread().getContextClassLoader().getResourceAsStream("sys-config.xml");
//得到xml所在位置。开始读取,并将数据放到doc中。
Document doc;
try {
doc = read.read(in);
//获取jdbc的配置信息
Element driverNameElement =(Element)doc.selectObject("/config/db-info/driver-name");
Element urlElement=(Element)doc.selectObject("/config/db-info/url");
Element usernameElement =(Element)doc.selectObject("/config/db-info/user-name");
Element passwordElement =(Element)doc.selectObject("/config/db-info/password");
//设置jdbc的配置信息
System.out.println(driverNameElement.getStringValue());
System.out.println(urlElement.getStringValue());
System.out.println(usernameElement.getStringValue());
System.out.println(passwordElement.getStringValue());
} catch (DocumentException e) {
e.printStackTrace();
}
}
}
运行结果如图: