1.不推荐只用此方法,使用内存严重,不过对于小文件还是可以使用的
2.DOM(Document Object Model),解析为一棵文档树放在内存中,文档树一般是文档实际大小的几倍,好处只是结构清晰,操作方便
3.实例演示
(1)Person.xml与Person.java见前一篇文章
(2)DOMParser.java
public class DOMPersonParser { public static List<Person> getPersons(InputStream inStream) throws Throwable { //建立一个list集合 List<Person> persons = new ArrayList<Person>(); //获取DocumentBuilderFactory对象实例 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); //把需要解析的内容传入解析,这里就已经完成解析了,返回文档树的形式 Document documnet = builder.parse(inStream); //取得文档树的根元素节点 Element root = documnet.getDocumentElement(); //调用Dom API去检索person元素节点 NodeList personNodes = root.getElementsByTagName("person"); for(int i=0 ; i < personNodes.getLength(); i++) { //强制把Person节点的元素转换为Element Element personElement = (Element)personNodes.item(i); // Person person = new Person(); //获取Person节点的id属性 person.setId(new Integer(personElement.getAttribute("id"))); //获取Person的子节点(元素节点与文本节点) NodeList personChilds = personElement.getChildNodes(); for(int y=0 ; y < personChilds.getLength(); y++) { //判断当前节点是否是元素类型节点 if(personChilds.item(y).getNodeType()==Node.ELEMENT_NODE) { //把符合条件的节点强制转换为Element类型 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())); } } } //把当前Person加到集合中 persons.add(person); } return persons; } }