java.lang.NoClassDefFoundError错误解决办法

  

<强> java.lang.NoClassDefFoundError错误解决办法

  

<强>前言

  

在日常Java开发中,我们经常碰到java.lang.NoClassDefFoundError这样的错误,需要花费很多时间去找错误的原因,具体是哪个类不见了?类明明还在,为什么找不到?而且我们很容易把java.lang.NoClassDefFoundError和java.lang.ClassNotfoundException这两个错误搞混,事实上这两个错误是完全不同的。我们往往花费时间去不断尝试一些其他的方法去解决这个问题,而没有真正去理解这个错误的原因。这篇文章就是通过解决NoClassDefFoundError错误处理的经验分享来揭开NoClassDefFoundError的一些秘密.NoClassDefFoundError的错误并非不能解决或者说很难解决,只是这种错误的表现形式很容易迷惑其他的Java开发者。下面我们来分析下为什么会发生NoClassDefFoundError这样的错误,以及怎样去解决这个错误。

  

<强> NoClassDefFoundError错误发生的原因

  

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

  

简单总结就是,NoClassDefFoundError发生在编译时对应的类可用,而运行时在Java类路径的路径中,对应的类不可用导致的错误。发生NoClassDefFoundError错误时,你能看到如下的错误日志:

        异常的线程“主要”java.lang.NoClassDefFoundError      

错误的信息很明显地指明主要线程无法找到指定的类,而这个主要线程可能时主线程或者其他子线程。如果是主线程发生错误,程序将崩溃或停止,而如果是子线程,则子线程停止,其他线程继续运行。

  

<强> NoClassDefFoundError和ClassNotFoundException区别

  

我们经常被java.lang.ClassNotFoundException和. lang。NoClassDefFoundError这两个错误迷惑不清,尽管他们都与Java类路径有关,但是他们完全不同.NoClassDefFoundError发生在JVM在动态运行时,根据你提供的类名,在类路径中找到对应的类进行加载,但当它找不到这个类时,就发生了java.lang.NoClassDefFoundError的错误,而ClassNotFoundException是在编译的时候在类路径中找不到对应的类而发生的错误.ClassNotFoundException比NoClassDefFoundError容易解决,是因为在编译时我们就知道错误发生,并且完全是由于环境的问题导致。而如果你在J2EE的环境下工作,并且得到NoClassDefFoundError的异常,而且对应的错误的类是确实存在的,这说明这个类对于类加载器来说,可能是不可见的。

  

<强>怎么解决NoClassDefFoundError错误

  

根据前文,很明显NoClassDefFoundError的错误是因为在运行时类加载器在类路径下找不到需要加载的类,所以我们需要把对应的类加载到类路径中,或者检查为什么类在类路径中是不可用的,这个发生可能的原因如下:

  
      <李>对应的类在java的类路径中不可用李   <李>你可能用jar命令运行你的程序,但类并没有在jar文件的清单文件中的类路径属性中定义李   <李>可能程序的启动脚本覆盖了原来的类路径环境变量   <李>因为NoClassDefFoundError是java.lang.LinkageError的一个子类,所以可能由于程序依赖的原生的类库不可用而导致李   <李>检查日志文件中是否有java.lang.ExceptionInInitializerError这样的错误,NoClassDefFoundError有可能是由于静态初始化失败导致的李   <李>如果你工作在J2EE的环境,有多个不同的类加载器,也可能导致NoClassDefFoundError
      李   
  

下面我们看一些当发生NoClassDefFoundError时,我们该如何解决的样例。

  

<强> NoClassDefFoundError解决示例

  

当发生由于缺少jar文件,或者jar文件没有添加到类路径中,或者jar的文件名发生变更会导致. lang。NoClassDefFoundError的错误。
  

  

当类不在类路径中时,这种情况很难确切的知道,但如果在程序中打印出System.getproperty (“java.classpath”),可以得到程序实际运行的类路径
  

  

运行时明确指定你认为程序能正常运行的类路径参数,如果增加之后程序能正常运行,说明原来程序的类路径被其他人覆盖了。

  

NoClassDefFoundError也可能由于类的静态初始化模块错误导致,当你的类执行一些静态初始化模块操作,如果初始化模块抛出异常,哪些依赖这个类的其他类会抛出NoClassDefFoundError的错误。如果你查看程序日志,会发现一些java.lang.ExceptionInInitializerError的错误日志,ExceptionInInitializerError的错误会导致. lang。NoClassDefFoundError:无法初始化类,如下面的代码示例:

java.lang.NoClassDefFoundError错误解决办法