解析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. C++常用容器

    vector 顺序容器,和数组类似,可从尾部快速的插入和删除,可随机访问. vector的常用成员函数: #include<vector> std::vector<type> ...

  2. 谈谈 JavaScript 中的 this 指向问题

    JavaScript 中的 this 为一个重难点,它不像静态语言 C#.Java 一样,就表示当前对象.而在 JS 中, this 是运行时确定,而并非定义时就已确定其值. 谈起 this ,必须少 ...

  3. LVM 创建分区扩展分区记录

    LVM 原理   图片来自百度百科   测试环境centOS 7                 LVM version:     2.02.115(2)-RHEL7 (2015-01-28)     ...

  4. HCTF2016-杂项签到

    题目下载了一个+_+.pcapng ,用Wireshark打开, Ctrl-F搜索flag 发现python代码 将Data导出 #!/usr/bin/env python # coding:utf- ...

  5. 发布方配ASP.NET网站服务器

    方配ASP.NET网站服务器是一款简单,轻量,灵活的ASP.NET网站服务器,使用它可以无需安装复杂的IIS,直接就可以运行ASP.NET网站,使用非常简单,把exe文件拷贝到ASP.NET的网站目录 ...

  6. Codeforces Round #192 (Div. 1) C. Graph Reconstruction 随机化

    C. Graph Reconstruction Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/3 ...

  7. iOS开发——UI_swift篇&UITableView实现单元格展开与隐藏

    UITableView实现单元格展开与隐藏  关于UITableView的展开的收缩在前面的文章我已经结束,就是使用代理,通知,block传值的时候实现的,当时是使用一个Bool值来实现,最后使用着三 ...

  8. iOS开发——UI_swift篇&UItableView实现移动单元格

    UItableView实现移动单元格   1,下面的样例是给表格UITableView添加单元格移动功能: (1)给表格添加长按功能,长按后表格进入编辑状态 (2)在编辑状态下,可以看到单元格后面出现 ...

  9. iOS开发——新特性篇&swift新特性(__nullable和__nonnull)

    swift新特性(__nullable和__nonnull) 最近在看老师写代码的时候经常遇到两个陌生的关键字,但是当我在我的电脑上敲得时候就是敲不出,后来才知道这是为了swift与OC混编的时候产生 ...

  10. 利用nf_conntrack机制存储路由,省去每包路由查找

    IP是无连接的,因此IP路由是每包一路由的,数据包通过查找路由表获取路由,这是现代操作协议协议栈IP路由的默认处理方式.可是假设协议栈具有流识别能力,是不是能够基于流来路由呢?答案无疑是肯定的. 设计 ...