国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

實例解析Android中使用Pull解析器解析XML的方法

2019-12-12 06:39:51
字體:
來源:轉載
供稿:網友

1.Pull簡介
Pull解析器是Android系統內置的的,Pull解析器與SAX解析器類似,他提供了類似的事件,如開始元素和介紹元素的事件,使用parser.next()可以進入下一個元素并觸發相應的事件,然后進行相應的處理,當元素開始解析時,調用perser.nextText()方法就可以獲取到下一個Text類型元素的值。

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


3.src結構
項目包名為 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目錄先新建一個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

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;        } } 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜昌市| 山阴县| 海安县| 平武县| 东乌珠穆沁旗| 乐业县| 宁津县| 永寿县| 宿迁市| 渑池县| 宣汉县| 金秀| 临邑县| 修水县| 会理县| 辰溪县| 卢湾区| 沽源县| 永吉县| 行唐县| 易门县| 景德镇市| 江阴市| 定安县| 繁峙县| 兰州市| 松江区| 东山县| 连平县| 沙田区| 乌审旗| 邓州市| 连江县| 南乐县| 开平市| 平乡县| 丹江口市| 泰兴市| 安达市| 天全县| 嵩明县|