android网络编程之pull解析xml
除了前面介绍过的SAX以及DOM方法,还可以通过Pull对xml文档进行一个解析。Pull解析器的解析方式与SAX非常相似。它提供了类似的事件,使用parser.next()可以进入下一元素并触发相应事件,事件将作为数值代码被发送,因此可以使用一个switch对感兴趣的事件进行选择,然后进行相应的处理,调用parser.nextText()方法可以获取下一个Text类型元素的值。
pull解析器特点:
*结构简单:一个接口、一个例外、一个工厂就组成了Pull解析器
*简单易用:只有5个事件:
1.START_DOCUMENT--->开始解析事件
2.START_TAG--->开始元素
3.END_TAG--->结束元素
4.TEXT--->解析文本
5.END_DOCUMENT--->结束解析事件
直接看代码:
public class PullPersonParse { /** * 使用pull技术解析xml * @param inStream * @return * @throws Throwable */ public static ArrayList<Person> pullParsePersons(InputStream inStream) throws Throwable{ ArrayList<Person> persons = null; Person person = null; XmlPullParser parser = Xml.newPullParser(); parser.setInput(inStream, "UTF-8"); int eventType = parser.getEventType();//产生第一个事件 while(eventType!=XmlPullParser.END_DOCUMENT){//只要不是文档结束解析事件 switch (eventType) { case XmlPullParser.START_DOCUMENT://开始解析事件 persons = new ArrayList<Person>(); break; case XmlPullParser.START_TAG://开始元素 String name = parser.getName();//获取解析器当前指向的元素的名称 if("person".equals(name)){ person = new Person(); person.setId(new Integer(parser.getAttributeValue(0))); } if(person!=null){ if("name".equals(name)){ person.setName(parser.nextText());//获取解析器当前指向元素的下一个文本节点的值 } if("age".equals(name)){ person.setAge(new Short(parser.nextText())); } } break; case XmlPullParser.END_TAG://结束元素 if("person".equals(parser.getName())){ persons.add(person); person = null; } break; } eventType = parser.next(); } return persons; } }
从内存占用率和执行效率方面考虑,应该尽量优先考虑sax和pull方式进行xml文件的解析。
时间: 2024-10-13 00:52:35