EasyExcel中AnalysisEventListener<T>抽象类的方法执行顺序

EasyExcel中AnalysisEventListener<T>抽象类 的方法执行顺序 ,我结合EasyExcel读取Excel的完整流程,把触发时机、调用链、执行先后讲得清清楚楚:

一、先明确核心前提

  1. 这个类是EasyExcel读取Excel的核心监听器 ,实现了ReadListener<T>接口,专门处理Excel的表头读取、数据行读取、读取完成逻辑;
  2. 你贴的代码里,invokeHead框架主动调用 的方法,它内部会直接调用 invokeHeadMap
  3. 执行顺序严格遵循「实例化 → 读表头 → 读数据行 → 读取完成」的Excel读取流程。

二、完整执行顺序(从启动到结束)

总共5个核心步骤,按先后顺序排列:

第1步:执行【构造方法】
  • 触发时机 :你创建监听器对象 时(比如new ExcelListener()),JVM自动调用;
  • 方法public AnalysisEventListener()
  • 作用:初始化监听器对象,最先执行。
第2步:框架调用【invokeHead】(读原始表头)
  • 触发时机 :EasyExcel读取到Excel表头行时,框架自动回调;
  • 方法public void invokeHead(...)
  • 作用 :接收Excel原始表头数据(ReadCellData格式),是表头处理的入口方法
第3步:自动调用【invokeHeadMap】(转字符串表头)
  • 触发时机第2步执行完后,立即自动调用 (代码里写死this.invokeHeadMap(...));
  • 方法public void invokeHeadMap(...)
  • 作用 :把原始表头转成Map<Integer, String>(列号→表头文字),这个方法是空实现,留给你重写来处理表头。
第4步:循环执行【invoke】(读每一行数据)
  • 触发时机 :表头读完后,逐行读取Excel数据行,每读一行执行一次;
  • 方法void invoke(T data, AnalysisContext context)(来自ReadListener接口,你贴的抽象类没实现,子类必须重写);
  • 作用:处理每一行的业务数据。
第5步:执行【doAfterAllAnalysed】(读取完成)
  • 触发时机:所有行(表头+数据)都读取完毕后,最后执行;
  • 方法void doAfterAllAnalysed(AnalysisContext context)(来自ReadListener接口,子类重写);
  • 作用:收尾工作(比如数据汇总、关闭资源)。

三、核心调用链(你代码里的关键逻辑)

invokeHead直接调用invokeHeadMap

这两个方法是连续执行 的,没有间隔,框架只触发invokeHead,剩下的invokeHeadMap由它内部主动调用。


总结

  1. 最先执行:构造方法(对象创建);
  2. 表头处理:invokeHead(框架调)→ 立即执行invokeHeadMap(内部调);
  3. 数据处理:循环执行invoke(每一行数据);
  4. 最后执行:doAfterAllAnalysed(读取结束)。
相关推荐
悟空码字2 小时前
别再让你的SpringBoot包"虚胖"了!这份瘦身攻略请收好
java·spring boot·后端
szm02252 小时前
操作系统-
java·linux·服务器
哆啦A梦15882 小时前
java项目在后端做跨域配置
java·vue3
用户8307196840822 小时前
从互斥锁到无锁,Java 20年并发安全进化史
java
盐水冰2 小时前
【烘焙坊项目】后端搭建(13)- 数据统计--图形报表
java·后端·学习·spring
易雪寒2 小时前
Java List 根据List中对象的属性值是否相同作为同一组,分割成多个连续的子List
java·数据结构·list·分组切割
小王不爱笑1322 小时前
Kubernetes(K8s)核心知识点
java
桑榆肖物2 小时前
.NET 10 Native AOT 在 Linux 嵌入式设备上的实战
java·linux·.net·aot
墨着染霜华2 小时前
Java实战:封装Redis非阻塞分布式锁,彻底解决表单重复提交主键冲突
java·redis·分布式