Android PULL解析XML文件(二)

本文对比SAX解析方法,介绍了PULL解析XML的优势及其工作原理。PULL允许开发者主动控制解析流程,仅提取所需的XML数据部分,从而节省资源。文章详细展示了如何使用PULL解析器读取XML文件中的特定元素。

   上一篇文章学习了SAX解析XML文件,接下来学习另一种方法PULL。

   如果在一个XML文档中我们只需要前面一部分数据,但是使用SAX方式或DOM方式会对整个文档进行解析,尽管XML文档中后面的大部分数据我们其实都不需要解析,因此这样实际上就浪费了处理资源。使用PULL方式正合适。

    Pull解析器和SAX解析器虽有区别但也有相似性。他们的区别为:SAX解析器的工作方式是自动将事件推入注册的事件处理器进行处理,因此你不能控制事件的处理主动结束;而Pull解析器的工作方式为允许你的应用程序代码主动从解析器中获取事件,正因为是主动获取事件,因此可以在满足了需要的条件后不再获取事件,结束解析。这是他们主要的区别。

    而他们的相似性在运行方式上,Pull解析器也提供了类似SAX的事件,开始文档START_DOCUMENT和结束文档END_DOCUMENT,开始元素START_TAG和结束元素END_TAG,遇到元素内容TEXT等,但需要调用next() 方法提取它们(主动提取事件)。(来自度娘 = = )

—————————————————————————————————————————————

   用法相较于SAX的区别在于对文件的解析方式:(PS:学完SAX,pull还是很好理解的)

   SAX需要一个帮助类,其中重写五个方法,重点在于character,endelement和startelement方法,根据XML的结构重写就可以了


接下来说一下PULL解析:

  方法形式和SAX差不多,START_DOCUMENT,END_DOCUMENT,START_TAG,END_TAG,.next(获取标签的属性值)

case XmlPullParser.START_DOCUMENT:  
                             mList = new ArrayList<Person>(); // 初始化person集合  
                             break;  
                         // 判断当前事件是否为标签元素开始事件  
                         case XmlPullParser.START_TAG:  
                             if (xpp.getName().equals("person")) { // 判断开始标签元素是否是person  
                                 person = new Person();  
                             } else if (xpp.getName().equals("name")) {  
                                 eventType = xpp.next();//让解析器指向name属性的值  
                                 // 得到name标签的属性值,并设置person的name  
                                 beauty.setName(xpp.getText());  
                             } else if (xpp.getName().equals("age")) { // 判断开始标签元素是否是person  
                                 eventType = xpp.next();//让解析器指向age属性的值  
                                 // 得到age标签的属性值,并设置person的age  
                                 beauty.setAge(xpp.getText());  
                             }   
                             break;  
                
                         // 判断当前事件是否为标签元素结束事件  
                         case XmlPullParser.END_TAG:  
                             if (xpp.getName().equals("person")) { // 判断结束标签元素是否是person
                                 mList.add(person); // 将person添加到person集合  
                                 person = null;  
                             }  
                             break;  
                         }  
                         // 进入下一个元素并触发相应事件  
                         eventType = xpp.next();
看出和SAX大致相同,主函数中使用方法如下:

需要建一个所需类的链表,然后解析xml文件。

 //通过assertmanager的open方法获取到beauties.xml文件的输入流  
            InputStream is = this.getAssets().open("beauties.xml");  
            //初始化自定义的实现类BeautyParserImpl  
            BeautyParserImpl pbp = new BeautyParserImpl();  
            //调用pbp的parse()方法,将输入流传进去解析,返回的链表结果赋给beautyList  
            beautyList = pbp.parse(is);

如果要在网络上下载XML文件并解析的话,需要上一篇所写的HttpDownloader 类来实现。然后主函数里对于网络的操作相同。

Mainifest.xml文件设置中添加访问网络的权限:

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值