除了可以使用 SAX解析XML文件,也可以使用熟悉的DOM来解析XML文件。
DOM解析XML文件时,会将XML文件的所有内容以对象树方式存放在内存中,然后允许您使用DOM API遍历XML树、检索所需的数据。使用DOM操作XML的代码看起来比较直观,并且,在某些方面比基于SAX的实现更加简单。但是,因为DOM需要将XML文件的所有内容以对象树方式存放在内存中,所以内存的消耗比较大,特别对于运行Android的移动设备来说,因为设备的资源比较宝贵,所以建议还是采用SAX来解析XML文件,当然,如果XML文件的内容比较小采用DOM是可行的。
person.xml文件:
<?xml version="1.0" encoding="utf-8"?>
<persons>
<person id="21">
<name>hanmeimei</name>
<age>23</age>
</person>
<person id="27">
<name>lilei</name>
<age>25</age>
</person>
</persons>
利用DOM解析文件的代码:
/**
* 利用DOM来解析xml文件
*/
public class DOMPersonService {
public static List<Person> getPersons( InputStream inStream) throws Exception{
List<Person> persons = new ArrayList<Person>();
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
//请注意此处引用的都是import org.w3c.dom.Document;等等
Document document = builder.parse(inStream);
Element root = document.getDocumentElement();
NodeList personNodes = root.getElementsByTagName("person");
for(int i = 0;i < personNodes.getLength();i++){
Person person = new Person();
Element personElement = (Element)personNodes.item(i);
int id = Integer.parseInt(personElement.getAttribute("id"));
person.setId(id);
NodeList childNodes = personElement.getChildNodes();
for(int j = 0;j < childNodes.getLength();j++){
Node childNode = childNodes.item(j);
if(childNode.getNodeType() == Element.ELEMENT_NODE){
if("name".equals(childNode.getNodeName())){
//注意此处
String name = childNode.getFirstChild().getNodeValue();
person.setName(name);
}else if("age".equals(childNode.getNodeName())){
String age = childNode.getFirstChild().getNodeValue();
person.setAge(new Short(age));
}
}
}
persons.add(person);
}
return persons;
}
}