项目中使用Reflections扫描自定义注解,根据注解的值做逻辑处理。部分添加注解的类扫描不到,对比扫描到的类发现,代码没有任何问题,项目也没有异常日志打印出来,debug看源码发现Reflections类打印异常信息的日志级别为debug。在org.reflections.Reflections#scan(java.net.URL)方法中

追踪源码,在此方法中点击scanner.scan(file, classObject)进入,实现类是org.reflections.scanners.AbstractScanner

点击configuration.getMetadataAdapter().getOfCreateClassObject(file)进入,实现类是org.reflections.adapters.JavassistAdapter

这个地方会报异常
在项目中利用Reflections进行自定义注解扫描时,遇到部分类无法扫描的问题。排查过程中发现Reflections的日志级别为debug,通过跟踪源码发现异常发生在JavassistAdapter的getOfCreateClassObject方法,抛出`java.io.IOException: invalid constant type 18`。问题可能与jar包的Javassist版本不兼容有关,但升级Javassist版本并未解决问题。进一步分析指出,问题可能由Java 8的lambda表达式引起,转换lambda为常规代码后解决了问题。
订阅专栏 解锁全文
2320

被折叠的 条评论
为什么被折叠?



