个人学习笔记之 pull解析XML

1.Pull简介

Pull解析器是Android系统内置的的,Pull解析器与SAX解析器类似,他提供了类似的事件,如开始元素和介绍元素的事件,使用 parser.next()可以进入下一个元素并触发相应的事件,然后进行相应的处理,当元素开始解析时,调用perser.nextText()方法就 可以获取到下一个Text类型元素的值。

2.pull特点

一.简单的结构,一个接口,一个另外,一个工厂组成了Pull解析器

二.简单易用,Pull解析器只有一个重要的方法next(),他被用来检索下一个事件,而他的事件也仅仅只有五个,START_DOCUMENT, START_TAG ,TEXT, END_TAG, END_DOCUMENT

三.最小的内存消耗,Pull解析器和SAX解析器一样,对内存的暂用少,但是SAX解析稍微有点繁琐,DOM很耗内存,所以Pull被推荐使用

3,示例 Pull解析XML

先在src目录先新建一个android.xml

    <?xml version="1.0" encoding="UTF-8"?>  
    <persons>  
        <person id="23">  
            <name>xiaanming</name>  
            <age>23</age>  
        </person>  
        <person id="20">  
            <name>liudehua</name>  
            <age>28</age>  
        </person>  
    </persons>  

新建一个PullXMLService.java

    package com.example.pull_parser;  
      
    import java.io.InputStream;  
    import java.util.ArrayList;  
    import java.util.List;  
      
    import org.xmlpull.v1.XmlPullParser;  
      
    import android.util.Log;  
    import android.util.Xml;  
      
    public class PullXMLService {  
        public static List<Person> readXML() throws Exception{  
            //获取src目录下面的android.xml文件的输入流   
            InputStream is = PullXMLService.class.getClassLoader().getResourceAsStream("android.xml");  
            //用来存放解析的Person对象   
            List<Person> persons = null;  
            //一个标记   
            boolean flag = false;  
            Person person = null;  
              
            //实例化一个XmlPullParser对象   
            XmlPullParser parser = Xml.newPullParser();  
              
            //设置输入流和编码   
            parser.setInput(is, "UTF-8");  
              
            //触发了第一个事件,根据XML的语法,也就是从他开始了解文档   
            int eventCode = parser.getEventType();  
              
            //如果获得的事件码如果是文档的结束,那么解析结束  
            while (eventCode != XmlPullParser.END_DOCUMENT) {  
                switch(eventCode){  
                case XmlPullParser.START_DOCUMENT:{  
                    //开始解析的时候我们一般做一些初始化的操作  
                    persons = new ArrayList<Person>();  
                    break;  
                }  
                case XmlPullParser.START_TAG:{  
                    //判断当前的元素是否是需要检索的元素   
                    if("person".equals(parser.getName())){  
                        flag = true;  
                        person = new Person();  
                        person.setId(Integer.valueOf(parser.getAttributeValue(0)));  
                    }  
                    if(flag){  
                        if("name".equals(parser.getName())){  
                            person.setName(parser.nextText());  
                        }else if("age".equals(parser.getName())){  
                            person.setAge(Integer.valueOf(parser.nextText()));  
                        }  
                    }  
                    break;  
                }  
                case XmlPullParser.END_TAG:{  
                    if("person".equals(parser.getName()) && person != null){  
                        flag = false;  
                        persons.add(person);  
                        Log.e("log", person.toString());  
                        person = null;  
                    }  
                    break;  
                }  
                }  
                  
                //这一步很重要,该方法返回一个事件码,也是触发下一个事件的方法  
                eventCode = parser.next();  
            }  
              
            return persons;  
              
        }  
    }  

好了,这样子就解析完了android.xml 是不是很方便很简单呢,比SAX和DOM要更容易理解.

原文地址:https://www.cnblogs.com/lichone2010/p/3127843.html