NoClassDefFoundError和之间有什么区别ClassNotFoundException?
NoClassDefFoundError
ClassNotFoundException
是什么导致它们被抛出?如何解决?
在修改现有代码以包含新的jar文件时,我经常遇到这些throwables。我在客户端和服务器端都通过Webstart分发了一个Java应用程序。
我遇到的可能原因:
build.xml
今天,当我遇到这些问题时,我会采取一种犯错的方法来使事情正常进行。我需要更多的清晰度和理解。
与Java API规范的区别如下。
对于ClassNotFoundException:
当应用程序尝试使用其字符串名称通过其字符串名称加载类时抛出:
forName
Class
findSystemClass
ClassLoader
loadClass
但是找不到具有指定名称的类的定义。
对于NoClassDefFoundError:
如果Java虚拟机或ClassLoader实例尝试加载类的定义(作为常规方法调用的一部分或使用新表达式创建新实例的一部分)而抛出,则找不到该类的定义。
当前正在编译的类在编译时就存在搜索到的类定义,但是无法再找到该定义。
因此,似乎NoClassDefFoundError在成功编译源代码时发生了,但是在运行时class未找到所需的文件。这可能是在分发或生成JAR文件时发生的,其中未class包含所有必需的文件。
至于ClassNotFoundException,似乎是由于试图在运行时对类进行反射性调用而引起的,但是程序尝试调用的类不存在。
两者之间的区别在于,一个是an Error,另一个是an Exception。with NoClassDefFoundError是Error,它来自Java虚拟机,它在查找期望找到的类时遇到问题。由于class找不到文件,或者与编译时生成或遇到的文件不同,预期无法在编译时工作的程序无法运行。这是一个非常严重的错误,因为该程序无法由JVM启动。
an Error
an Exception
with NoClassDefFoundError
Error
另一方面,ClassNotFoundException是一个Exception,因此在某种程度上是可以预期的,并且可以恢复。使用反射可能会容易出错(因为有些期望可能不会按预期进行。没有进行编译时检查以确保所有必需的类都存在,因此查找所需类的任何问题都会在运行时出现。
Exception