NoClassDefFoundError与ClassNotFoundException

时间:2023-03-08 17:51:12

原文地址:

https://blog.****.net/jamesjxin/article/details/46606307

怎么解决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

ClassNotFoundException

在运行一个spark项目时,提示ClassNotFoundException: org.apache.conf.Configuration, 原因是在maven的pom文件中,将hadoop-common依赖的scope标签设置成了provided,表示在运行时会提供此依赖,因此该依赖仅在编译和测试时有效,但在运行时无效。解决方法是在开发环境运行时加入-cp=/path/to/jar.jar 或者临时将此依赖范围标签去掉(即使用默认的compile范围)。

补充:什么时候会抛出classnotfoundException异常呢?当程序试图使用class类中的forname方法、classloader类中的findsystemclass方法,classloader类中loadclass方法通过字符串名的形式加载此类时,会抛出该异常。前面提到的maven依赖范围为provided这种情形,应该是jvm加载类时找不到类文件导致的。