例:
<?xml version="1.0" encoding="UTF-8"?>
<bookstore>
<book id="1" name='book1'>
<name>挪威的森林</name>
<author>村上春树</author>
<year>2019</year>
<price>89</price>
</book>
<book id="2" name='book2'>
<name>设计模式</name>
<year>2018</year>
<price>386</price>
<language>English</language>
</book>
</bookstore>
DOM文档对象模型(10M文档时内存溢出)
优点:
1、形成了树结构,有助于更好的理解、掌握,且代码容易编写。
2、解析过程中,树结构保存在内存中,方便修改。
缺点:
1、由于文件是一次性读取,所以对内存的耗费比较大。
2、如果XML文件比较大,容易影响解析性能且可能会造成内存溢出。
public static void main(String[] args) {
//创建一个DocumentBuilderFactory的对象
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
//创建一个DocumentBuilder的对象
try {
//创建DocumentBuilder对象
DocumentBuilder db = dbf.newDocumentBuilder();
//通过DocumentBuilder对象的parser方法加载data.xml文件到当前项目下
Document document = db.parse("src/com/xml/data.xml");
//获取所有book节点的集合
NodeList bookList = document.getElementsByTagName("book");
//通过nodelist的getLength()方法可以获取bookList的长度
System.out.println("book节点个数【" + bookList.getLength() + "】");
//遍历每一个book节点
for (int i = 0; i < bookList.getLength(); i++) {
System.out.println("=================下面开始遍历第" + (i + 1) + "个节点=================");
//通过 item(i)方法 获取一个book节点,nodelist的索引值从0开始
Node book = bookList.item(i);
//获取book节点的所有属性集合
NamedNodeMap attrs = book.getAttributes();
//遍历book的属性
for (int j = 0; j < attrs.getLength(); j+&#