Pull解析器是Android官方推荐的轻量高效XML解析方式,采用主动拉取模式,由程序控制解析节奏,内存占用小,适合移动设备中按需提取特定字段的场景。

Pull解析器是一种基于“拉取”模式的XML解析方式,核心特点是应用程序主动向解析器请求下一个事件(比如开始标签、文本内容、结束标签),而不是由解析器自动把事件“推送”给程序。它在Android平台被官方推荐,轻量、高效、可控性强。
Pull是“你问它答”,SAX是“它说你听”
SAX采用事件驱动模型:解析器一边读XML,一边自动触发startElement、endElement等回调,你只能被动接收、处理。一旦开始解析,就得走完全程,中途不好停。
Pull则不同:你用parser.next()主动获取下一个事件类型(如START_TAG、TEXT、END_TAG),再用parser.nextText()取文本值。整个过程由你控制节奏——想读到某个节点就停,不需要的数据直接跳过。
- 适合只关心XML中某几段内容的场景(比如只取
和) - 可随时跳出while循环,节省CPU和时间
- 代码结构更线性,比SAX少写Handler类,逻辑更直观
DOM是“全盘加载”,Pull是“按需读取”
DOM会把整个XML文件一次性读进内存,构建成一棵完整的树形对象(Document→Element→Text…),之后你可以随意访问、修改、回溯任意节点。好处是操作灵活,缺点是内存占用大——对Android这种资源受限环境很不友好。
Pull根本不建树,也不保存历史节点,只维持当前解析位置。它不缓存数据,也不提供父/子/兄弟节点导航能力,纯粹靠一次遍历完成提取任务。
- 内存占用极小,适合移动设备
- 无法反向查找或多次遍历同一份XML
- 不能直接修改或生成XML(需配合其他API)
适用场景对比很实际
选Pull:Android端解析配置文件、网络返回的轻量级XML响应(如天气简报、RSS摘要),尤其当你只需要前几个字段、或想快速失败退出时。
选SAX:需要完整扫描但内存敏感,且能接受固定回调结构(比如日志解析、批量导入)。
选DOM:XML很小(
基本上就这些。










