Android에서는 일반적으로 SAX 작업, Pull 작업, DOM 작업 등 xml 파일을 작업하는 방법이 여러 가지가 있습니다. 그 중 DOM 방식은 누구에게나 가장 친숙할 뿐만 아니라 W3C 표준에도 부합합니다.
XML은 업계에서 인정하는 데이터 교환 형식으로 다음에서 사용할 수 있습니다. 다양한 플랫폼과 언어가 널리 사용되고 구현됩니다. 표준형, 신뢰성, 안전성... 의심의 여지가 없습니다. Android 플랫폼에서는 데이터 저장 및 데이터 교환을 구현하려는 경우 xml 데이터 형식과 xml 파일을 사용하는 경우가 많습니다.
팁: Android에 저장되는 데이터에는 일반적으로 SharedPreferences(매개변수화), XML 파일, sqllite 데이터베이스, 네트워크, ContentProvider(콘텐츠 공급자) 등의 유형이 포함됩니다.
Android에서는 일반적으로 SAX 작업, Pull 작업, DOM 작업 등 xml 파일을 작업하는 방법이 여러 가지가 있습니다. 그 중 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 구문 분석 표준입니다. 핸들러 모드는 일반적으로 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 구문 분석과 매우 유사합니다. 둘 다 경량 구문 분석이므로 Pull을 지원하기 위해 타사 jar 패키지를 추가할 필요가 없습니다. 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을 작동하는 세 가지 방법 요약의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!