java.lang.NoClassDefFoundError: Could not initialize class xxx

感慨:啊啊啊啊啊啊啊啊啊啊,这个问题弄了我好久,整整一天!!!

概述:原本是调用公司自己写的jar包的工具类。在其他项目都能调用,一模一样的套用过来就是不行。问了一些同事他们也不知道怎么解决。

   然后百度上网查资料,网上大多数都是说jar包冲突,或者读不到配置文件,静态方法什么的。因为这是公司内部写的工具jar包,应该不会存在冲突的。我还是

   检查了jar包,因为我另外一个项目调这个方法是没问题的。所以我把j整个项目的jar包几乎改成和另外一个项目一样的。还是没用(中途包括网上查的先降级在升级jar什么的,都试过)。

   

   项目重启,各种clean install 重新编译还是没用。真的是奇了怪了。

   网上说读不到配置文件。我看了我那个工具类,他虽然是有配置文件,但是也是配置在他jar包里面的,无需我配置啊。再说了我另外一个可以运行的项目也没配置其他的。百思不得其解。

   在已经放弃的边缘,我想说,实在不行换种方式实现吧!

   因为我另外一个项目一样的用法是没有问题的,所以我几乎对比了这个两个项目的所有不同点。能保持一样的都保持一样了。

   其中有个问题,我们的项目都是springboot,在启动类那里,

//原本没问题的项目
@ComponentScan("aaa.bbb.ccc")

//报错的项目
@ComponentScan

开始的时候知道这里不同,但是每太注意,因为

@ComponentScan的作用是扫描其包所在的位置下面的所有包
@ComponentScan("aaa.bbb.ccc")的作用是扫描指定路径下的所有包

然后感觉也没问题,就没太注意。
但是,当你很绝望的时候,什么都要去试一下的。
然后我把这里也改成了一样。就可以了!!!!

最后就知道为什么了

原因就是
我们公司的默认路径都是
aaa.bbb.ccc.项目名(ddd).启动类(App.java)

@ComponentScan没配置扫描路径的时候,就是扫描 aaa.bbb.ccc.项目名(ddd) 下的包
@ComponentScan("aaa.bbb.ccc")确实扫描的 aa.bbb.ccc 下的包,没有 项目名(ddd)这一层

而我调用的公用工具包是公司自己写的,都是以公司的名称命名的,所以那些配置文件都是放到 aaa.bbb.ccc 下的
没有项目名(ddd)。@ComponentScan不指定路径的话,是扫描不到工具jar包里面的类的(扫描不到类,意味着他们的注解是不可以用的),就会导致他们读不到配置文件,
所以在调用静态方法的时候,就会报 java.lang.NoClassDefFoundError: Could not initialize class xxx

所以,最终问题确实是归结到 静态代码块读不到 配置文件的内容!!!!




原文地址:https://www.cnblogs.com/zml-java/p/11480318.html