NoClassDefFoundError出现包括以下情况
- 包冲突,包括但不限于包路径一样,找不到类。
- jar包未加载
- 类初始化失败
首先明确不管什么原因NoClassDefFoundError都是由于jvm未加载到class导致的,对于不使用maven或者其他依赖管理的应用排查起来比较麻烦,需要具体问题具体分析。
对于使用maven管理的应用,依赖冲突排查比较容易,不在赘述。我所遇到的问题排查流程
首先排查MANIFEST.MF文件是否有jar包以及路径是否正确,这里一般不会有问题,根据排查流程还是要看下。
在排查jar包的类的路径是否正确,可以把jar包解压使用javap -p className,查看类是否正确。这里排查完后如果还是没有问题,说明1.2情况基本排除。
这时候为了排查跟jar路径是否有关系就可以把使用的jar放到jre/lib目录下,使用扩展类加载器进行加载,如果以上都没有问题就基本确定为类初始化失败了。我所遇见的也是这种情况,当把jar放到jre/lib目录下释,报错信息也发生了变化,可以明确在栈信息中看到第一行有 .<clinit>报错,这个就是静态代码块有问题导致了类初始化失败,到此排查结束。