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(读取结束)。
相关推荐
yaoxin5211239 小时前
434. Java 日期时间 API - Period 基于日期的时间段
java·开发语言·python
何极光10 小时前
IDEA集成Maven
java·maven·intellij-idea
程序员二叉11 小时前
【JUC】ThreadLocal底层原理|内存泄漏|弱引用|跨线程传递方案
java·开发语言·面试·职场和发展·juc
程序员二叉11 小时前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc
老马识途2.011 小时前
在AI的帮助下理解spring的启动过程
java·前端·spring
青山木11 小时前
Hot 100 --- 轮转数组
java·数据结构·算法
Qt程序员11 小时前
掌握 Linux 内核调度:从原理到实现(进程篇)
java·开发语言
code bean11 小时前
【LangChain】检索器完全指南:从向量检索到生产级 RAG 架构
java·开发语言·微服务
大白菜和MySQL11 小时前
java应用排查高线程
java·python
KobeSacre12 小时前
ReentrantLock源码
java