原文:http://javarevisited.blogspot.com/2011/06/noclassdeffounderror-exception-in.html
处理这个错误经常犯的2个错误,一是混淆NoClassDefFoundError和ClassNotFoundException。二是盲目地去重试而不去真正理解NoClassDefFoundError产生的原因。
那么产生NoClassDefFoundError的真正原因是什么?
jvm在运行时找不到某个类,但是编译的时候能找到。比如我们调用某个类的某一个方法,或者使用它静态成员变量,然而这个类在运行时不可用,就会出NoClassDefFoundError。
简单说当某个类在编译时可用但是运行时不可用的时候就会抛出NoClassDefFoundError。
NoClassDefFoundError和ClassNotFoundException的区别?
基本上这两个错误都是和classpath有关,但是原因有不同。
ClassNotFoundException:当jvm运行时动态加载某个类时发生的。也就是说jvm在运行时才知道类的名字然后根据名字去找没找到。
NoClassDefFoundError:出问题的类在编译时可用(所以编译通过),但是运行时不可用。
NoClassDefFoundError更好解决一些,因为这完全是环境的问题。需要检查出错的类是否在classpath中,或者查出为什么它不在classpath中。原因可能是:
1, 类不在classpath中。
2,使用jar命令运行程序但是manifest文件中没有定义classpath属性
3,启动脚本覆盖了classpath环境变量
4,由于NoClassDefFoundError是java.lang.LinkageError的一个子类,所以可能它的依赖不可用
5,在log中找找有没有ExceptionInInitializerError,静态初始化失败产生的NoClassDefFoundError也很常见
6,如果使用j2ee,多个classloader也可导致NoClassDefFoundError。