android中采用Pull解析XML文档

昨天晚上在复习了android中采用Pull解析xml文档在这里分享给大家。

老规矩让我们先来了解一下Pull解析器解析xml文档的原理,在android中系统内置大多数都是采用pull来解析xml的那么它的原理是什么呢??嘿嘿!其实这个和我们前面学的SAX解析技术原理差不多都是采用事件驱动来解析整个文档,那么为什么有了SAX还用pull干撒呢?多此一举(我也这么认为的哈!!)但是采用pull 解析xml文档从效率上和SAX差不多的但是Pull解析器的可读性上优于SAX,我们也不需要解析出整个文档(在某些情况下)就可以得到先关的数据。

那么怎么个工作的呢?不急!它的工作流程和SAX也是相同的唯一的不同就是在触发某个事件的时候Pull不是像SAX那样去回调一些函数,而是触发某个事件返回一些整数我们根据返回的这些数据来对相应的事件触发的某个特定元素做相应的操作那么下面就来看看代码吧!

public class PullParseService {

private List<Person> ls=null;
private Person person=null;

public List<Person> PullParse(InputStream inputStream)
{
XmlPullParser parser=Xml.newPullParser();
try {
parser.setInput(inputStream, "UTF-8");
int eventType=parser.getEventType();
while(eventType!=XmlPullParser.END_DOCUMENT)
{
switch (eventType) {
//开始文档事件
case XmlPullParser.START_DOCUMENT:
ls=new ArrayList<Person>();
break;
//开始元素事件
case XmlPullParser.START_TAG:
String name = parser.getName();
if(name.equals("person"))
{
person=new Person();
person.setId(new Integer(parser.getAttributeValue(null, "id")));
}
else if(person!=null)
{
if(name.equals("name"))
{
person.setName(parser.nextText());
}else if(name.equals("age"))
{
person.setAge(new Integer(parser.nextText()));
}
}

break;
//结束元素事件
case XmlPullParser.END_TAG:
if(person!=null)
{
if(parser.getName().equals("person"))
{
ls.add(person);
person=null;
}
}
break;
}
//推向下一个事件
eventType=parser.next();
}
inputStream.close();
} catch (Exception e) {

e.printStackTrace();
}
return ls;
}
}

 

下面是我写的单元测试方法:

 

public void testreadPullParse() throws Throwable{
PullParseService service = new PullParseService();
InputStream inStream = getClass().getClassLoader().getResourceAsStream("person.xml");
List<Person> persons = service.PullParse(inStream);
for(Person person : persons){
Log.i(TAG, person.toString());
}
}

xml 文档person.xml

<?xml version="1.0" encoding="UTF-8"?>
<persons>
<person id="23">
<name>liming</name>
<age>30</age>
</person>
<person id="20">
<name>lixiangmei</name>
<age>25</age>
</person>
</persons>

 

....

你可能感兴趣的:(pull xml)