欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

實(shí)例解析Android中使用Pull解析器解析XML的方法

 更新時(shí)間:2016年04月07日 17:35:36   作者:xiaanming  
這篇文章主要介紹了Android中使用Pull解析器解析XML的方法,與DOM和SAX解析方式相比人們更推崇Pull,需要的朋友可以參考下

1.Pull簡介
Pull解析器是Android系統(tǒng)內(nèi)置的的,Pull解析器與SAX解析器類似,他提供了類似的事件,如開始元素和介紹元素的事件,使用parser.next()可以進(jìn)入下一個(gè)元素并觸發(fā)相應(yīng)的事件,然后進(jìn)行相應(yīng)的處理,當(dāng)元素開始解析時(shí),調(diào)用perser.nextText()方法就可以獲取到下一個(gè)Text類型元素的值。

2.pull特點(diǎn)
(1)簡單的結(jié)構(gòu),一個(gè)接口,一個(gè)另外,一個(gè)工廠組成了Pull解析器
(2)簡單易用,Pull解析器只有一個(gè)重要的方法next(),他被用來檢索下一個(gè)事件,而他的事件也僅僅只有五個(gè),START_DOCUMENT, START_TAG ,TEXT, END_TAG, END_DOCUMENT
(3)最小的內(nèi)存消耗,Pull解析器和SAX解析器一樣,對內(nèi)存的暫用少,但是SAX解析稍微有點(diǎn)繁瑣,DOM很耗內(nèi)存,所以Pull被推薦使用


3.src結(jié)構(gòu)
項(xiàng)目包名為 com.pullxml.mypull,在src根目錄下存在person.xml文件

-- com.pullxml.util
-- -- Person.java
-- com.pullxml.mypull
-- -- MainAcitivity.java
-- com.pullxml.service
-- -- PullService.java
-- com.pullxml.test
-- -- PullTester.java
-- person.xml

4.示例 Pull解析XML
先在src目錄先新建一個(gè)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> 

新建一個(gè)PullXMLService

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; 
    //一個(gè)標(biāo)記 
    boolean flag = false; 
    Person person = null; 
     
    //實(shí)例化一個(gè)XmlPullParser對象 
    XmlPullParser parser = Xml.newPullParser(); 
     
    //設(shè)置輸入流和編碼 
    parser.setInput(is, "UTF-8"); 
     
    //觸發(fā)了第一個(gè)事件,根據(jù)XML的語法,也就是從他開始了解文檔 
    int eventCode = parser.getEventType(); 
     
    //如果獲得的事件碼如果是文檔的結(jié)束,那么解析結(jié)束 
    while (eventCode != XmlPullParser.END_DOCUMENT) { 
      switch(eventCode){ 
      case XmlPullParser.START_DOCUMENT:{ 
        //開始解析的時(shí)候我們一般做一些初始化的操作 
        persons = new ArrayList<Person>(); 
        break; 
      } 
      case XmlPullParser.START_TAG:{ 
        //判斷當(dāng)前的元素是否是需要檢索的元素 
        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; 
      } 
      } 
       
      //這一步很重要,該方法返回一個(gè)事件碼,也是觸發(fā)下一個(gè)事件的方法 
      eventCode = parser.next(); 
    } 
     
    return persons; 
     
  } 
} 

相關(guān)文章

最新評論