xml序列化是把内存数据写入硬盘或SD卡。
XML文件解析的方式:
1、dom解析,生成一个树状结构,并全部加入内存,在内存修改树状结构的节点即可。但是消耗内存大。
2、sax解析 基于事件的解析方式。速度快,效率高,但是不能倒退。
3、pull解析 基于事件的解析
pull解析方式:
第一步,初始化解析器,设置要解析的数据流。(此刻指向文档的开始部分)
第二步,得到事件。
第三步,总的节点集合。
第四步,单个节点。
public class PullXMLTools {
public PullXMLTools() {
// TODO Auto-generated constructor stub
}
/**
* @param inputStream
* 从服务器获取xml文件,以流的形式返回
* @param encode
* 编码格式
* @return
* @throws Exception
*/
public static List<Person> parseXML(InputStream inputStream, String encode)
throws Exception {
List<Person> list = null;
Person person = null;// 装载解析每一个person节点的内容
// 创建一个xml解析的工厂
XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
// 获得xml解析类的引用
XmlPullParser parser = factory.newPullParser();
parser.setInput(inputStream, encode);
// 获得事件的类型
int eventType = parser.getEventType();
while (eventType != XmlPullParser.END_DOCUMENT) {
switch (eventType) {
case XmlPullParser.START_DOCUMENT:
list = new ArrayList<Person>();
break;
case XmlPullParser.START_TAG:
if ("person".equals(parser.getName())) {
person = new Person();
// 取出属性值
int id = Integer.parseInt(parser.getAttributeValue(0));
person.setId(id);
} else if ("name".equals(parser.getName())) {
String name = parser.nextText();// 获取该节点的内容
person.setName(name);
} else if ("age".equals(parser.getName())) {
int age = Integer.parseInt(parser.nextText());
person.setAge(age);
}
break;
case XmlPullParser.END_TAG:
if ("person".equals(parser.getName())) {
list.add(person);
person = null;
}
break;
}
eventType = parser.next();
}
return list;
}
}
xml文件是persons person
利用Java类加载可以加载工程中的xml文件: