首页 > 技术文章 > pull解析和sax解析的差别

mengfanrong 2016-03-09 13:37 原文

假设在一个XML文档中我们仅仅须要前面一部分数据。可是使用SAX方式或DOM方式会对整个文档进行解析,虽然XML文档中后面的大部分数据我们事实上都不须要解析。因此这样实际上就浪费了处理资源。

使用PULL方式正合适。

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

这是他们基本的差别。

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

    Android系统中和Pull方式相关的包为org.xmlpull.v1。在这个包中提供了Pull解析器的工厂类XmlPullParserFactory和Pull解析器XmlPullParser,XmlPullParserFactory实例调用newPullParser方法创建XmlPullParser解析器实例,接着XmlPullParser实例就能够调用getEventType()和next()等方法依次主动提取事件,并依据提取的事件类型进行对应的逻辑处理。

    //创建XmlPullParser,有两种方式   
    //方式一:使用工厂类XmlPullParserFactory   
    XmlPullParserFactory pullFactory = XmlPullParserFactory.newInstance();   
    XmlPullParser xmlPullParser = pullFactory.newPullParser();   
    //方式二:使用Android提供的有用工具类android.util.Xml  
    XmlPullParser xmlPullParser = Xml.newPullParser(); 

    XmlPullParser.setInput(InputStream inputStream, String inputEncoding) 解析相应的输入文件

    XmlPullParser.getEventType() 得到元素

    推断元素是否是START_DOCUMENT、END_DOCUMENT、START_TAG、END_TAG、TEXT中的那种,进行对应解析。
 PULL方式比較简单,并且能够依据推断停止解析(DOM和SAX都须要对文件的文章解析中途不能停止)。

推荐阅读