SAX解析器通过startElement和endElement方法实现事件驱动解析:前者在遇到开始标签时触发,用于获取标签名和属性;后者在结束标签时调用,用于收尾处理,二者需配对使用并配合characters方法完成文本提取。
SAX解析器不构建整个文档树,而是边读边触发回调方法。其中 startElement 和 endElement 是最核心的两个方法,分别在遇到开始标签和结束标签时被自动调用。
空间这个方法在每次解析到一个开始标签(如 )时触发。它会传入标签的命名空间URI、本地名、完整标签名(qName),以及该标签的所有属性。
attributes.getValue("id")
当解析器遇到对应结束标签(如 )时调用。参数和 startElement 类似,但一般只关心标签名,用来“收尾”之前 startElement 开启的逻辑。
时,可以把已收集的作者文本存进当前 book 对象多数场景下,你需要用成员变量暂存上下文信息:
基本上就这些。关键不是死记方法签名,而是理解它们在解析流中的位置和职责——startElement 是“进门”,endElement 是“出门”,中间的 characters 才是“说话”。