Android进阶之XML文件解析

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文件:






你可能感兴趣的:(Android进阶之XML文件解析)