一尘不染

Java-什么原因导致NoClassDefFoundError和ClassNotFoundException之间有什么区别?

java

NoClassDefFoundError和之间有什么区别ClassNotFoundException

是什么导致它们被抛出?如何解决?

在修改现有代码以包含新的jar文件时,我经常遇到这些throwables。我在客户端和服务器端都通过Webstart分发了一个Java应用程序。

我遇到的可能原因:

  1. build.xml代码客户端未包含的软件包
  2. 我们正在使用的新jar缺少运行时类路径
  3. 版本与先前的jar冲突

今天,当我遇到这些问题时,我会采取一种犯错的方法来使事情正常进行。我需要更多的清晰度和理解。


阅读 392

收藏
2020-02-25

共1个答案

一尘不染

与Java API规范的区别如下。

对于ClassNotFoundException

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

  • forName课堂教学中的方法Class
  • findSystemClass课堂教学中的方法ClassLoader
  • loadClass课堂教学中的方法ClassLoader

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

对于NoClassDefFoundError

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

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

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

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

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

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

2020-02-25