关于怎么解决java.lang.NoClassDefFoundError错误

五一在部署新的统一登陆时,遇到这样一个问题:java

很容易把java.lang.NoClassDefFoundError和java.lang.ClassNotfoundException这两个错误搞混,事实上这两个错误是彻底不一样的。spa

NoClassDefFoundError错误发生的缘由

NoClassDefFoundError错误的发生,是由于Java虚拟机在编译时能找到合适的类,而在运行时不能找到合适的类致使的错误。例如在运行时咱们想调用某个类的方法或者访问这个类的静态成员的时候,发现这个类不可用,此时Java虚拟机就会抛出NoClassDefFoundError错误。与ClassNotFoundException的不一样在于,这个错误发生只在运行时须要加载对应的类不成功,而不是编译时发生。不少Java开发者很容易在这里把这两个错误搞混。.net

简单总结就是,NoClassDefFoundError发生在编译时对应的类可用,而运行时在Java的classpath路径中,对应的类不可用致使的错误。日志

NoClassDefFoundError和ClassNotFoundException区别

咱们常常被java.lang.ClassNotFoundException和java.lang.NoClassDefFoundError这两个错误迷惑不清,尽管他们都与Java classpath有关,可是他们彻底不一样。NoClassDefFoundError发生在JVM在动态运行时,根据你提供的类名,在classpath中找到对应的类进行加载,但当它找不到这个类时,就发生了java.lang.NoClassDefFoundError的错误,而ClassNotFoundException是在编译的时候在classpath中找不到对应的类而发生的错误。ClassNotFoundException比NoClassDefFoundError容易解决,是由于在编译时咱们就知道错误发生,而且彻底是因为环境的问题致使。而若是你在J2EE的环境下工做,而且获得NoClassDefFoundError的异常,并且对应的错误的类是确实存在的,这说明这个类对于类加载器来讲,多是不可见的。blog

怎么解决NoClassDefFoundError错误

根据前文,很明显NoClassDefFoundError的错误是由于在运行时类加载器在classpath下找不到须要加载的类,因此咱们须要把对应的类加载到classpath中,或者检查为何类在classpath中是不可用的,这个发生可能的缘由以下:开发

  1. 对应的Class在java的classpath中不可用
  2. 你可能用jar命令运行你的程序,但类并无在jar文件的manifest文件中的classpath属性中定义
  3. 可能程序的启动脚本覆盖了原来的classpath环境变量
  4. 由于NoClassDefFoundError是java.lang.LinkageError的一个子类,因此可能因为程序依赖的原生的类库不可用而致使
  5. 检查日志文件中是否有java.lang.ExceptionInInitializerError这样的错误,NoClassDefFoundError有多是因为静态初始化失败致使的(这是我遇到的问题的解决办法)
  6. 若是你工做在J2EE的环境,有多个不一样的类加载器,也可能致使NoClassDefFoundError。
  7. NoClassDefFoundError也可能因为类的静态初始化模块错误致使,当你的类执行一些静态初始化模块操做,若是初始化模块抛出异常,哪些依赖这个类的其余类会抛出NoClassDefFoundError的错误。若是你查看程序日志,会发现一些java.lang.ExceptionInInitializerError的错误日志,ExceptionInInitializerError的错误会致使java.lang.NoClassDefFoundError: Could not initialize class
相关文章
相关标签/搜索