用PULL解析XML文件时循环的过程
XML文件内容如下(名字为"teacher.xml") 使用PULL解析XML文件的代码: import java.io.FileReader; import java.io.IOException; import java.util.ArrayList; import java.util.List; import org.xmlpull.v1.XmlPullParser; import org.xmlpull.v1.XmlPullParserException; import org.xmlpull.v1.XmlPullParserFactory; public class PullTry { public static void main(String[] args) { List<Teacher> datas = null; Teacher teacher = null; try { XmlPullParserFactory factory = XmlPullParserFactory.newInstance(); XmlPullParser parser = factory.newPullParser(); parser.setInput(new FileReader("teacher.xml")); int eventType = parser.getEventType(); while (eventType != XmlPullParser.END_DOCUMENT) { String tagName = parser.getName(); switch (eventType) { case XmlPullParser.START_DOCUMENT: // 创建list datas = new ArrayList<>(); break; case XmlPullParser.START_TAG: // 创建Teacher对象 if ("teacher".equals(tagName)) { teacher = new Teacher(); } else if ("name".equals(tagName)) { teacher.setName(parser.nextText()); } else if ("age".equals(tagName)) { teacher.setAge(Integer.parseInt(parser.nextText())); } else if ("money".equals(tagName)) { teacher.setMoney(Double.parseDouble(parser.nextText())); } break; case XmlPullParser.END_TAG: // 把对象添加进List集合中 if ("teacher".equals(tagName)) { datas.add(teacher); } break; default: break; } // 将eventType指向下一步... eventType = parser.next(); } } catch (XmlPullParserException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } for (int i = 0; i < datas.size(); i++) { System.out.println(datas.get(i)); } System.out.println(count); } } 这里主要看while循环内部是如何读取xml文件的.. 首先循环的条件是eventType != XmlPullParser.END_DOCUMENT 如果eventType不等于XmlPullParser.END_DOCUMENT,就进行下一次循环。这里eventType的值有11种,但用到的只有前5种。 public static final int START_DOCUMENT = 0; public static final int END_DOCUMENT = 1; public static final int START_TAG = 2; public static final int END_TAG = 3; public static final int TEXT = 4; 为了观察循环执行的过程,我在循环内添加了一行代码: 其中count是循环运行的次数。添加这行代码后控制台显示出如下信息: 0===第1次循环===null 先说一下,只有在下一次eventType值为4(也即下一次循环时读取了TEXT)的情况下,读取的内容parser.nextText()不为空 ????结合xml文件来看,可以得出结论: 第一次循环,eventType值为0,也即START_DOCUMENT的情况。此时tagName值为空。 第二次循环,eventType值为2,也即START_TAG的情况。此时tagName值为teachers。也就是说此时读取到了<teachers>这个标签。由于下一次eventType值为4,也即TEXT的情况,所以此次读取的内容parser.nextText()值为<teachers>标签到<teacher>标签中间的文本内容!也就是一个n加一个t。 第三次循环,eventType值为4,也即TEXT的情况。此时tagName值为空。 第四次循环,eventType值为2,也即START_TAG的情况。此时tagName值为teacher。也就是说此时读取到了<teacher>这个标签。注意:此时if语句判断出"teacher".equals(tagName)返回值为true,会执行下面的teacher = new Teacher();来创建一个Teacher类的对象。由于下一次eventType值为4,也即TEXT的情况,所以此次读取的内容parser.nextText()值为<teacher>标签到<name>标签中间的文本内容,也就是一个n加两个t。 第五次循环,eventType值为4,也即TEXT的情况。此时tagName值为空。 第六次循环,eventType值为2,也即START_TAG的情况。此时tagName值为name。也就是说此时读取到了<name>这个标签。注意:此时if语句判断出"name".equals(tagName)返回值为true,会执行下面的teacher.setName(parser.nextText());,这里的parser.nextText()值应该是zhangsan。这样就把zhangsan赋值给了这个teacher对象的name属性。 第七次循环,eventType值为4,也即TEXT的情况。此时tagName值为空。 后面好像不用讲什么了,都是一个意思。 ps: 每一次遇到一个Teacher标签(Teacher标签是一个子标签,Teachers是父标签)都会创建一个对象,接着把里面的孙标签(name、age和money)赋值到这个对象的属性中。 ps2: 这个例子中孙标签中的endtag不会被读取。(就是</name>这种..) xbox: eventType值为3的情况只有三种,这三种情况下tagName值分别为teacher、teacher和teachers。进一步说明了ps2是对的..... (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |