Android-使用Pull对XML进行增删改查

0. Thanks

Android解析XML的三种方式
Android几种解析XML方式的比较
android xml 解析 修改
android 对xml文件的pull解析,生成xml ,对xml文件的增删
Android中xml 解析三种方式的区别

1.概述

  • PULL是google推荐的解析方式,它和SAX很像,也是从基于流式,从头开始扫描。不过,我们可以控制是否进行下一步扫描,而SAX不行,SAX是一股脑地扫描到文档末尾。而PULL可以在我们扫描到想要的内容后,就直接结束。

  • 简单地说就是对文档进行顺序扫描,当扫描到文档(document)开始与结束、元素(element)开始与结束、文档(document)结束等地方时通知事件处理函数,由事件处理函数做相应动作,然后继续同样的扫描,直至文档结束。

  • 为了方便说明,先约定好一个XML如下:



    
        zhangsan
        21
    

2.基本读取(查)

  • 基本事件类型:

  • XmlPullParser.START_DOCUMENT:文档开头

  • XmlPullParser.END_DOCUMENT:文档末尾

  • XmlPullParser.START_TAG:标签开始

  • XmlPullParser.END_TAG:标签结束

  • 代码如下

File file = new File(xmlFilePath);
try {
    InputStream inputStream = new FileInputStream(file);
    XmlPullParser parser = Xml.newPullParser();//得到Pull解析器
    parser.setInput(inputStream, "UTF-8");//设置下输入流的编码
    int eventType = parser.getEventType();//得到第一个事件类型
    while (eventType != XmlPullParser.END_DOCUMENT) {//如果事件类型不是文档结束的话则不断处理事件
        switch (eventType) {
            case (XmlPullParser.START_DOCUMENT)://如果是文档开始事件
                Log.i("loadWithPull","START_DOCUMENT");
                break;
            case (XmlPullParser.START_TAG)://如果遇到标签开始
                String tagName = parser.getName();// 获得解析器当前元素的名称
                Log.i("loadWithPull","START_TAG:"+tagName);
                for (int i = 0; i < parser.getAttributeCount(); i++) {
                    Log.i("loadWithPull","attr:"+parser.getAttributeName(i)+":"+parser.getAttributeValue(i));
                }
                if (!parser.isEmptyElementTag()) {
                    Log.i("loadWithPull","content:"+parser.getText());
                }
                break;
            case (XmlPullParser.END_TAG)://如果遇到标签结束
                Log.i("loadWithPull","END_TAG:"+parser.getName());
                break;
        }
        eventType=parser.next();//进入下一个事件处理
    }
    Log.i("loadWithPull","END_DOCUMENT");
} catch (Exception e) {
    e.printStackTrace();
}
  • 在扫描到tag的开始,我们便可以读取参数和其内容,如果有内容的话。
  • 使用上面的代码,得到的部分log如下:
I/loadWithPull: START_DOCUMENT
I/loadWithPull: START_TAG:persons
I/loadWithPull: content:null
I/loadWithPull: START_TAG:person
I/loadWithPull: attr:id:1
I/loadWithPull: attr:key:33
I/loadWithPull: attr:type:type
I/loadWithPull: content:null
I/loadWithPull: START_TAG:name
I/loadWithPull: content:null
I/loadWithPull: END_TAG:name
I/loadWithPull: START_TAG:age
I/loadWithPull: content:null
I/loadWithPull: END_TAG:age
I/loadWithPull: END_TAG:person
I/loadWithPull: END_TAG:persons
I/loadWithPull: END_DOCUMENT
  • 我们发现有些content为null,这是一些换行符,和一些tab。

3.保存,增删

  • 和sax的保存,删除,增加一样的做法:Android-使用SAX对XML进行增删改查

4.PULL,SAX,DOM比较

  • 说了那么多:
    Android-使用SAX对XML进行增删改查
    Android-使用Dom对XML进行增删改查

那么他们有什么区别吗?

  • 使用SAX解析XML

SAX(Simple API for XML) 使用流式处理的方式,它并不记录所读内容的相关信息。它是一种以事件为驱动的XML API,解析速度快,占用内存少。使用回调函数来实现。 缺点是不能中途结束。

  • 使用DOM解析XML

DOM(Document Object Model) 是一种用于XML文档的对象模型,可用于直接访问XML文档的各个部分。它是一次性全部将内容加载在内存中,生成一个树状结构,它没有涉及回调和复杂的状态管理。 缺点是加载大文档时效率低下。

  • 使用Pull解析XML

Pull内置于Android系统中。也是官方解析布局文件所使用的方式。Pull与SAX有点类似,都提供了类似的事件,如开始元素和结束元素。不同的是,SAX的事件驱动是回调相应方法,需要提供回调的方法,而后在SAX内部自动调用相应的方法。而Pull解析器并没有强制要求提供触发的方法。因为他触发的事件不是一个方法,而是一个数字。它使用方便,效率高。而且可以提前结束。

DOM SAX PULL
内存占用
解析速度
能否中断
随机访问
访问修改便利性
  • 如果只是查找某个字段某个值,推介PULL,如果要频繁修改,可以考虑DOM。当然要看实际情况,没有最优的解,只有最合适的解。

你可能感兴趣的:(Android-使用Pull对XML进行增删改查)