一尘不染

NoClassDefFoundError和ClassNotFoundException之间有什么区别?

java

NoClassDefFoundError和ClassNotFoundException之间有什么区别?


阅读 1183

收藏
2020-01-10

共1个答案

一尘不染

与Java API规范的区别如下。

对于ClassNotFoundException:

当应用程序尝试使用其字符串名称通过其字符串名称加载类时抛出:

  • forName类中的方法Class
  • findSystemClass类中的方法ClassLoader
  • loadClass类中的方法ClassLoader

但找不到具有指定名称的类的定义。

对于NoClassDefFoundError:

如果Java虚拟机或ClassLoader实例尝试加载类的定义(作为常规方法调用的一部分或使用新表达式创建新实例的一部分)而抛出,则找不到该类的定义。

当前正在编译的类在编译时就存在搜索到的类定义,但是无法再找到该定义。

因此,似乎NoClassDefFoundError在成功编译源代码时发生了,但是在运行时class找不到所需的文件。这可能是在分发或生成JAR文件时发生的,其中未class包含所有必需的文件。

至于ClassNotFoundException,似乎是由于试图在运行时对类进行反射性调用而引起的,但程序尝试调用的类不存在。

两者之间的区别在于,一个是Error,另一个是ExceptionNoClassDefFoundErrorError,它来自Java虚拟机,它在查找期望找到的类时遇到问题。由于class找不到文件,或者与编译时生成或遇到的文件不同,预期无法在编译时工作的程序无法运行。这是一个非常严重的错误,因为该程序无法由JVM启动。

另一方面,ClassNotFoundExceptionException,因此可以预料到,并且可以恢复。使用反射可能会容易出错(因为有些期望可能不会按预期进行。没有进行编译时检查以确保所有必需的类都存在,因此查找所需类的任何问题都会在运行时出现。

2020-01-10