DOM解析XML文件时,会将XML文件的所有内容以文档树方式存放在内存中,然后允许您使用DOM API遍历XML树,检索所需要的数据
使用DOM操作XML的代码看起来很直观的,并且在编码方面比基于SAX的实现更加的简单。但是,因为DOM需要将XML的所有内容以文档树方式
存放在内存中,所以内存的消耗比较大,特别对于运行android的移动设备来说,因为设备资源比较宝贵,所以建议海华丝采用SAX来
解析XML文件,当然,如果XML文件的内容比较小采用DOM也是可行的。
/**
* 采用DOM解析XML内容
*/
public class DOMPersonService {
public static List<Person> getPersons(InputStream inStream) throws Throwable{
List<Person> persons = new ArrayList<Person>();
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();//第一步
DocumentBuilder builder = factory.newDocumentBuilder();//第二步。。。
Document documnet = builder.parse(inStream);//第三步
Element root = documnet.getDocumentElement();
NodeList personNodes = root.getElementsByTagName("person");
for(int i=0 ; i < personNodes.getLength(); i++){
Person person = new Person();
Element personElement = (Element)personNodes.item(i);
person.setId(new Integer(personElement.getAttribute("id")));
NodeList personChilds = personElement.getChildNodes();
for(int y=0 ; y < personChilds.getLength(); y++){
if(personChilds.item(y).getNodeType()==Node.ELEMENT_NODE){//判断当前节点是否是元素类型节点
Element childElement = (Element)personChilds.item(y);
if("name".equals(childElement.getNodeName())){
person.setName(childElement.getFirstChild().getNodeValue());
}else if("age".equals(childElement.getNodeName())){
person.setAge(new Short(childElement.getFirstChild().getNodeValue()));
}
}
}
persons.add(person);
}
return persons;
}
}