XML作为一种业界公认的数据交换花样,在各个平台与言语之上,都有普遍运用和完成。其规范型,可靠性,安全性......毋庸置疑。在android平台上,我们要想完成数据存储和数据交换,常常会运用到xml数据花样和xml文件。
小提示:android中存储数据寻常有以下几种:SharedPreferences(参数化),XML文件,sqllite数据库,收集,ContentProvider(内容提供者)等。
在android中,操纵xml文件,寻常有几种体式格局:SAX操纵,Pull操纵,DOM操纵等。个中DOM的体式格局,多是人人最熟习的,也是相符W3C规范的。
1)
在java平台中,有诸如DOM4J如许优异的开源包,极大水平的轻易人人运用DOM规范来操纵XML文件。在javascript中,差别的浏览器剖析引擎,对DOM的剖析和操纵也略有差别(不过这不是本章引见的重点)。而DOM的体式格局,也有其瑕玷。一般一次性加载xml文件,再运用DOM的 api去举行剖析,如许很大水平的斲丧内存,对机能会有肯定影响。而我们的android手机,虽然设置在不停的升级,然则内存方面,临时还没法与传统的PC去媲美。所以,在android上面,不太引荐运用DOM的体式格局来剖析和操纵XML。
复制代码 代码以下:
package cn.itcast.service; import java.io.InputStream;import java.util.ArrayList;import java.util.List; import javax.xml.parsers.DocumentBuilder;import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document;import org.w3c.dom.Element;import org.w3c.dom.Node;import org.w3c.dom.NodeList; import cn.itcast.model.Person; public class DomPersonService { public List<Person> getPersons(InputStream stream) throws Throwable { List<Person> list =new ArrayList<Person>(); DocumentBuilderFactory factory =DocumentBuilderFactory.newInstance(); DocumentBuilder builder =factory.newDocumentBuilder(); Document dom = builder.parse(stream);//剖析完成,并以dom树的体式格局存放在内存中。比较斲丧机能 //最先运用dom的api去剖析 Element root = dom.getDocumentElement();//根元素 NodeList personNodes = root.getElementsByTagName("person");//返回一切的person元素节点 //最先遍历啦 for(int i=0;i<personNodes.getLength();i++) { Person person =new Person(); Element personElement =(Element)personNodes.item(i); person.setId(new Integer( personElement.getAttribute("id")));//将person元素节点的属性节点id的值,赋给person对象 NodeList personChildrenNodes =personElement.getChildNodes();//猎取person节点的一切子节点 //遍历一切子节点 for(int j=0;j<personChildrenNodes.getLength();j++) { //推断子节点是不是是元素节点(如果是文本节点,多是空缺文本,不处置惩罚) if(personChildrenNodes.item(j).getNodeType()==Node.ELEMENT_NODE) { //子节点--元素节点 Element childNode =(Element)personChildrenNodes.item(j); if("name".equals(childNode.getNodeName())) { //如果子节点的称号是“name”.将子元素节点的第一个子节点的值赋给person对象 person.setName(childNode.getFirstChild().getNodeValue()); }else if("age".equals(childNode.getNodeValue())) { person.setAge(new Integer(childNode.getFirstChild().getNodeValue())); } } } list.add(person); } return list; }}
2)
SAX(Simple API for XML),是一个运用异常普遍的XML剖析规范,一般运用Handler形式来处置惩罚XML文档,这类处置惩罚形式和我们寻常习气的明白体式格局很差别,身旁也常常有一些朋侪在刚打仗SAX的时刻会以为明白起来有些难题。实在SAX并不庞杂,只不过是换了一种头脑体式格局,正如它的名字所示意的,为了让我们以更简朴的体式格局来处置惩罚XML文档,下面我们就最先吧。
复制代码 代码以下:
package cn.itcast.service; import java.io.InputStream;import java.util.ArrayList;import java.util.List; import javax.xml.parsers.SAXParser;import javax.xml.parsers.SAXParserFactory; import org.xml.sax.Attributes;import org.xml.sax.SAXException;import org.xml.sax.helpers.DefaultHandler; import cn.itcast.model.Person; public class SAXPersonService { public List<Person> getPersons(InputStream inStream) throws Throwable { SAXParserFactory factory = SAXParserFactory.newInstance();//工场形式照样单例形式? SAXParser parser =factory.newSAXParser(); PersonParse personParser =new PersonParse(); parser.parse(inStream, personParser); inStream.close(); return personParser.getPerson(); } private final class PersonParse extends DefaultHandler { private List<Person> list = null; Person person =null; private String tag=null; public List<Person> getPerson() { return list; } @Override public void startDocument() throws SAXException { list =new ArrayList<Person>(); } @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { if("person".equals(localName)) { //xml元素节点最先时触发,是“person” person = new Person(); person.setId(new Integer(attributes.getValue(0))); } tag =localName;//保留元素节点称号 } @Override public void endElement(String uri, String localName, String qName) throws SAXException { //元素节点完毕时触发,是“person” if("person".equals(localName)) { list.add(person); person=null; } tag =null;//完毕时,须要清空tag } @Override public void characters(char[] ch, int start, int length) throws SAXException { if(tag!=null) { String data = new String(ch,start,length); if("name".equals(tag)) { person.setName(data); }else if("age".equals(tag)) { person.setAge(new Integer(data)); } } } } }
3)
Pull剖析和Sax剖析很类似,都是轻量级的剖析,在Android的内核中已嵌入了Pull,所以我们不须要再增加第三方jar包来支撑Pull。Pull剖析和Sax剖析不一样的处所有(1)pull读取xml文件后触发响应的事宜挪用要领返回的是数字(2)pull能够在顺序中掌握想剖析到哪里就能够住手剖析。
复制代码 代码以下:
package cn.itcast.service; import java.io.InputStream;import java.io.Writer;import java.util.ArrayList;import java.util.List; import org.xmlpull.v1.XmlPullParser;import org.xmlpull.v1.XmlSerializer; import android.util.Xml; import cn.itcast.model.Person; public class PullPersonService { //保留xml文件 public static void saveXML(List<Person> list,Writer write)throws Throwable { XmlSerializer serializer =Xml.newSerializer();//序列化 serializer.setOutput(write);//输出流 serializer.startDocument("UTF-8", true);//最先文档 serializer.startTag(null, "persons"); //轮回去增加person for (Person person : list) { serializer.startTag(null, "person"); serializer.attribute(null, "id", person.getId().toString());//设置id属性及属性值 serializer.startTag(null, "name"); serializer.text(person.getName());//文本节点的文本值--name serializer.endTag(null, "name"); serializer.startTag(null, "age"); serializer.text(person.getAge().toString());//文本节点的文本值--age serializer.endTag(null, "age"); serializer.endTag(null, "person"); } serializer.endTag(null, "persons"); serializer.endDocument(); write.flush(); write.close(); } public List<Person> getPersons(InputStream stream) throws Throwable { List<Person> list =null; Person person =null; XmlPullParser parser =Xml.newPullParser(); parser.setInput(stream,"UTF-8"); int type =parser.getEventType();//发生第一个事宜 //只需当前事宜范例不是”完毕文档“,就去轮回 while(type!=XmlPullParser.END_DOCUMENT) { switch (type) { case XmlPullParser.START_DOCUMENT: list = new ArrayList<Person>(); break; case XmlPullParser.START_TAG: String name=parser.getName();//猎取剖析器当前指向的元素称号 if("person".equals(name)) { person =new Person(); person.setId(new Integer(parser.getAttributeValue(0))); } if(person!=null) { if("name".equals(name)) { person.setName(parser.nextText());//猎取剖析器当前指向的元素的下一个文本节点的文本值 } if("age".equals(name)) { person.setAge(new Integer(parser.nextText())); } } break; case XmlPullParser.END_TAG: if("person".equals(parser.getName())) { list.add(person); person=null; } break; } type=parser.next();//这句万万别忘了哦 } return list; } }
下面是Model层的Person类的代码:
复制代码 代码以下:
package cn.itcast.model; public class Person {private Integer id;public Integer getId() { return id;}public void setId(Integer id) { this.id = id;} private String name;public String getName() { return name;} public void setName(String name) { this.name = name;} private Integer age;public Integer getAge() { return age;} public void setAge(Integer age) { this.age = age;} public Person(){}public Person(Integer id, String name, Integer age) { this.id = id; this.name = name; this.age = age;} @Overridepublic String toString() { return "Person [id=" + id + ", name=" + name + ", age=" + age + "]";} }
以上就是android三种操纵XML的要领总结的细致内容,更多请关注ki4网别的相干文章!