1.DOM解析
DOM是一种用于XML文档的对象模型,可用于直接访问XML文档的各个部分。它是一次性将全部内容加载到内存中,生成一个树状结构,它没有涉及回调和复杂的状态管理。缺点是加载大文档时,效率低下。
2.SAX解析
SAX使用流处理的方式,他并不记录所读内容的相关信息,它是一种以事件为驱动的XML API,解析速度快,占用内存少,使用回调函数来实现。缺点是不能倒退。
3.Pull解析
Pull内置于安卓系统中,也是官方解析布局文件所使用的方式。Pull和SAX有些类似,都提供了类似的事件,如开始元素和结束元素。不同的是,SAX的事件驱动是回调相应的方法,需要提供回调的方法,而后在SAX内部自动调用相应的方法。而Pull解析器并没有强制要求提供触发的方法。因为它触发的事件不是一个方法,而是一个数字。它使用方便,效率高。
4.比较:
- 内存占用:SAX,Pull比DOM要好。
- 编程方式:SAX采用事件驱动,在相应事件触发的时候,会调用用户编好的方法,也即每解析一类XML,就要编写一个新的适合该类XML的处理类。DOM是W3C的规范,Pull简洁。
- 访问和修改:SAX采用流式解析,DOM随机访问。
- 访问方式:SAX,Pull解析的方式是同步的,DOM逐字逐句。