解析XML的方式有DOM,SAX,PULL,那为什么要在Android中使用PULL解析呢?首先来说一下PULL解析的优点,然后再说一下其他两种解析方式的缺点,答案就清晰可见啦。

DOM不适合文档较大,内存较小的场景。DOM是基于树形结构的的节点或信息片段的集合,允许开发人员使用DOM API遍历XML树、检索所需数据。分析该结构通常需要加载整个文档和构造树形结构,然后才可以检索和更新节点信息。由于DOM在内存中以树形结构存放,因此检索和更新效率会更高。但是对于特别大的文档,解析和加载整个文档将会很耗资源。

SAX解析器操作太笨重,SAX(Simple API for XML)解析器是一种基于事件的解析器,它的核心是事件处理模式,主要是围绕着事件源以及事件处理器来工作的。当事件源产生事件后,调用事件处理器相应的处理方法,一个事件就可以得到处理。在事件源调用事件处理器中特定方法的时候,还要传递给事件处理器相应事件的状态信息,这样事件处理器才能够根据提供的事件信息来决定自己的行为。SAX解析器的优点是解析速度快,占用内存少。比较适合在Android移动设备中使用。

PULL解析的优点:①轻巧灵活,速度快。②占用内存下(很大的优势)③使用方便顺手。PULL解析器的运行方式和SAX类似,都是基于事件的模式。不同的是,在PULL解析过程中,我们需要自己获取产生的事件然后做相应的操作,而不像SAX那样由处理器触发一种事件的方法,执行我们的代码。PULL解析器小巧轻便,解析速度快,简单易用,非常适合在Android移动设备中使用,Android系统内部在解析各种XML时也是用PULL解析器。

那我接下来就介绍下PULL解析器:

首先在项目的assets目录中放置一个你要解析的XML文档person.xml,内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<persons>
       <person id="1">
             <name>john</name>
             <age>23</age>
       </person>
       <person id="2">
             <name>david</name>
             <age>233</age>
       </person>
</persons>

然后根据xml中person对象建模,Person.java如下:

package com.example.xml_paser;
public class Person {
    private int id;
    private String name;
    private int age;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
}

再使用PULLParser解析,代码如下:

package com.example.xml_paser;

import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;

import org.xmlpull.v1.XmlPullParser;

import android.content.Context;
import android.util.Log;
import android.util.Xml;

public class xml_paser {
    static final String TAG = "XMLPaser";
    private static final String ns = null;
    private Context context;

public xml_paser(Context applicationContext) {
        // TODO Auto-generated constructor stub
        this.context = applicationContext;
    }

public List<Person> parse(String xmlPath) {
        List<Person> psonList = new ArrayList<Person>();//创建person对象列表
        Person person = null;
        InputStream stream = null;
        // get xml parser
        XmlPullParser xmlParse = Xml.newPullParser();//创建XmlPullparser实例
        try {
            // get file stream and set encoding
            stream = this.context.getResources().getAssets().open(xmlPath);//初始化输入流
            xmlParse.setInput(stream, "utf-8");//设置输入流 并指明编码方式
            // get event type
            int evnType = xmlParse.getEventType();
            // continue to end document
            while (evnType != XmlPullParser.END_DOCUMENT) {
                switch (evnType) {
                case XmlPullParser.START_TAG:
                    String tag = xmlParse.getName();//获得解析标记名
                    if (tag.equalsIgnoreCase("person")) {//标记是person的情况
                        person = new Person();//创建person对象
                        person.setId(Integer.parseInt(xmlParse
                                .getAttributeValue(ns, "id")));//获得输入流中的id属性,赋值给新person对象的id
                    } else if (person != null) {
                        // parse after tag
                        if (tag.equalsIgnoreCase("name")) {
                            person.setName(xmlParse.nextText());//获得输入流中的name属性,赋值给新person对象的name
                        } else if (tag.equalsIgnoreCase("age")) {
                            person.setId(Integer.parseInt(xmlParse.nextText()));
                        }
                    }
                    break;
                case XmlPullParser.END_TAG:
                    if (xmlParse.getName().equalsIgnoreCase("person")
                            && person != null) {
                        psonList.add(person);//将person对象加入personlist中
                        person = null;
                    }
                    break;
                default:
                    break;
                }
                evnType = xmlParse.next();
            }
        } catch (Exception e) {
            Log.d(TAG, e.toString());
        }
        return psonList;
    }
}

最后,我们需要调用PULL解析程序,这个步骤在MainActivity中完成:

package com.example.xml_paser;
import java.util.List;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
public class MainActivity extends Activity {
    private Button btn_paserButton;
    private String urlString="person.xml";
    private xml_paser xml_paser;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        btn_paserButton=(Button)findViewById(R.id.button1);
        xml_paser=new xml_paser(getApplicationContext());
        btn_paserButton.setOnClickListener(new View.OnClickListener()
        {
            @Override
            public void onClick(View arg0) {
                // TODO Auto-generated method stub
                List<Person> list_per = xml_paser.parse(urlString);
                Log.v("bbb", list_per.size()+"");
                for (int i = 0; i < list_per.size(); i++)
                {
                    //Log.v("aaa",list_per.get(i));
                    Log.v("aaa", list_per.get(i).getName().toString()+"");
                }
            }
        });
    }
}

运行结果显示person的名字,结果如下:

Android中用PULL解析XML的更多相关文章

  1. Android之Pull解析XML

    一.Pull解析方法介绍 除了可以使用SAX和DOM解析XML文件,也可以使用Android内置的Pull解析器解析XML文件.Pull解析器的运行方式与SAX解析器相似.它也是事件触发的.Pull解 ...

  2. Android使用pull解析xml

    一.理论准备     Pull解析器的运行方式与 SAX 解析器相似.它提供了类似的事件,如:开始元素和结束元素事件,使用parser.next()可以进入下一个元素并触发相应事件.跟SAX不同的是, ...

  3. android——使用pull解析xml文件

    1.persons.xml 将persons.xml文件放到src目录下.其代码如下: <?xml version='1.0' encoding='UTF-8' standalone='yes' ...

  4. [android] 采用pull解析xml文件

    /***********2016年5月6日 更新**********************/ 知乎:Android 中有哪几种解析 xml 的类,官方推荐哪种 ? 以及它们的原理和区别? 刘吉财: ...

  5. Android中pull解析XML文件的简单使用

    首先,android中解析XML文件有三种方式,dom,sax,pull 这里先讲pull,稍候会说SAX和DOM pull是一种事件驱动的xml解析方式,不需要解析整个文档,返回的值是数值型,是推荐 ...

  6. Android使用pull解析xml格式的数据

    dom解析:基于全文加载的解析方式   sax解析:基于事件的逐行解析方式  pull解析:同sax              XmlPullParser     //解析xml文件读取短信内容    ...

  7. 使用PULL解析XML文件

    转载博文1:http://blog.csdn.net/wangkuifeng0118/article/details/7313241 XmlPull和Sax类似,是基于流(stream)操作文件,然后 ...

  8. Android——PULL解析XML

    简介 Android中常常使用XML文件保存用户的APP设置信息.因此需要对XML文件的相关操作进行了解.本文将以<学生信息管理系统>为案例背景进行介绍相关的XML解析的介绍,以及其他相关 ...

  9. Android系列--DOM、SAX、Pull解析XML

    您可以通过点击 右下角 的按钮 来对文章内容作出评价, 也可以通过左下方的 关注按钮 来关注我的博客的最新动态. 如果文章内容对您有帮助, 不要忘记点击右下角的 推荐按钮 来支持一下哦 如果您对文章内 ...

随机推荐

  1. RSS阅读器(一)——dom4j读取xml(opml)文件

    接触java不久,偶有收获,最近想做一个web版RSS阅读器来锻炼一下.手头有几个从不同版本的foxmail中导出的opml文件,大家应该都知道,opml文件就是xml格式的.那么就先从这里入手,练习 ...

  2. VHDL TestBench基础(转)

    TestBench的主要目标是: 实例化DUT-Design Under Test 为DUT产生激励波形 产生参考输出,并将DUT的输出与参考输出进行比较 提供测试通过或失败的指示 TestBench ...

  3. Unity3D行为树插件Behave学习笔记

    Behave1.4行为树插件 下载地址:http://pan.baidu.com/s/1i4uuX0L 安装插件和使用 我们先来看看插件的安装和基本使用方法,新建一个Unity3D项目,这里我使用的是 ...

  4. Hibernate映射解析——七种映射关系

    首先我们了解一个名词ORM,全称是(Object Relational Mapping),即对象关系映射.ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现,这样开发人员就可以把对 ...

  5. iOS开发-轻点、触摸和手势

    一.响应者链 以UIResponder作为超类的任何类都是响应者.UIView和UIControl是UIReponder的子类,因此所有视图和所有控件都是响应者. 初始相应器事件首先会传递给UIApp ...

  6. C#用天气预报的WebServices

    后台代码: protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { WeatherWS ws = new W ...

  7. goldengate的HANDLECOLLISIONS参数

    HANDLECOLLISIONS 是一个 replicat 进程参数,主要在 initial load 中使用. 在 replicat 进程中使用该参数时,即使目标数据库环境中存在数据完整性问题(如 ...

  8. UVA 1557 - Calendar Game(博弈dp)

    UVA 1557 - Calendar Game 题目链接 题意:给定一个日期,两个人轮流走,每次能够走一月或者一天,问最后谁能走到2001.11.4这个日子 思路:记忆化搜索,对于每一个日期,假设下 ...

  9. [GIF] The Phase Property in GIF Loop Coder

    In this lesson, we look at one of the most powerful features in GIF Loop Coder, the phase property, ...

  10. iOS开发——UI_swift篇&TableView自定义聊天界面

    TableView自定义聊天界面   1,下面是一个放微信聊天界面的消息展示列表,实现的功能有: (1)消息可以是文本消息也可以是图片消息 (2)消息背景为气泡状图片,同时消息气泡可根据内容自适应大小 ...