Java解析XML一般有两种方案,一种是pull,一种是Sax解析。两种解析原理是不太一样的,但各有优势。先来说说他们的原理以及优缺点。
pull解析XML是将整块XML文件读入手机内存再进行树形解析,对于内存小的手机自然是会有卡顿的反应,而且解析的途中无法停止,倘若一个xml有几十M,效率还蛮低,但是解析出的数据信息是对称的,也就是成功率很高。
Sax(全 称 Simple API for XML)解析是将XML逐行解析,程序运行时占用内存不大,非常适合手机等嵌入式设备,但代码写起来的时候有些怪异,而且解析途中会莫名其妙出现空值或脏 数据,这让我非常苦闷,不过解决方法还是有的。还有一个优点就是可以随时停止解析,毕竟它是逐行解析。想了解更多详见Java API的org.xml.sax。
现在来说说Sax的运行机制:
//声明SAX解析工厂
SAXParserFactory factory = SAXParserFactory.newInstance();
//通过解析工厂类构造XMLReader对象
XMLReader reader = factory.newSAXParser().
pull解析XML是将整块XML文件读入手机内存再进行树形解析,对于内存小的手机自然是会有卡顿的反应,而且解析的途中无法停止,倘若一个xml有几十M,效率还蛮低,但是解析出的数据信息是对称的,也就是成功率很高。
Sax(全 称 Simple API for XML)解析是将XML逐行解析,程序运行时占用内存不大,非常适合手机等嵌入式设备,但代码写起来的时候有些怪异,而且解析途中会莫名其妙出现空值或脏 数据,这让我非常苦闷,不过解决方法还是有的。还有一个优点就是可以随时停止解析,毕竟它是逐行解析。想了解更多详见Java API的org.xml.sax。
现在来说说Sax的运行机制:
//声明SAX解析工厂
SAXParserFactory factory = SAXParserFactory.newInstance();
//通过解析工厂类构造XMLReader对象
XMLReader reader = factory.newSAXParser().