NoClassDefFoundError和ClassNotFoundException之间有什么区别?
与Java API规范的区别如下。
当应用程序尝试使用其字符串名称通过其字符串名称加载类时抛出:
forName
类中的方法Class
。findSystemClass
类中的方法ClassLoader
。loadClass
类中的方法ClassLoader
。但找不到具有指定名称的类的定义。
如果Java虚拟机或ClassLoader
实例尝试加载类的定义(作为常规方法调用的一部分或使用新表达式创建新实例的一部分)而抛出,则找不到该类的定义。
当前正在编译的类在编译时就存在搜索到的类定义,但是无法再找到该定义。
因此,似乎NoClassDefFoundError
在成功编译源代码时发生了,但是在运行时class找不到所需的文件。这可能是在分发或生成JAR文件时发生的,其中未class包含所有必需的文件。
至于ClassNotFoundException
,似乎是由于试图在运行时对类进行反射性调用而引起的,但程序尝试调用的类不存在。
两者之间的区别在于,一个是Error
,另一个是Exception
。NoClassDefFoundError
是Error
,它来自Java虚拟机,它在查找期望找到的类时遇到问题。由于class找不到文件,或者与编译时生成或遇到的文件不同,预期无法在编译时工作的程序无法运行。这是一个非常严重的错误,因为该程序无法由JVM启动。
另一方面,ClassNotFoundException
是Exception
,因此可以预料到,并且可以恢复。使用反射可能会容易出错(因为有些期望可能不会按预期进行。没有进行编译时检查以确保所有必需的类都存在,因此查找所需类的任何问题都会在运行时出现。
ClassNotFoundException和NoClassDefFoundError之间有什么区别? 谁能举个例子来解释。。
问题内容: 和之间有什么区别? 是什么导致它们被抛出?如何解决? 在修改现有代码以包含新的jar文件时,我经常遇到这些throwables。我在客户端和服务器端都通过Webstart分发了一个Java应用程序。 我遇到的可能原因: 代码客户端未包含的软件包 我们正在使用的新jar缺少运行时类路径 版本与先前的jar冲突 今天,当我遇到这些问题时,我会采取一种犯错的方法来使事情正常进行。我需要更多的
问题内容: 和之间有什么区别? 是什么导致它们被抛出?如何解决? 在修改现有代码以包含新的jar文件时,我经常遇到这些throwables。我在客户端和服务器端都通过Webstart分发了一个Java应用程序。 我遇到的可能原因: build.xml代码客户端未包含的软件包 我们正在使用的新jar缺少运行时类路径 版本与先前的jar冲突 今天,当我遇到这些问题时,我会采取一种犯错的方法来使事情正常
和之间有什么区别? 是什么原因导致他们被扔?如何解决这些问题? 在修改现有代码以包含新的jar文件时,我经常会遇到这些可抛物。我在通过WebStart发布的一个Java应用程序的客户端和服务器端都碰到了它们。 我遇到的可能原因是: 代码客户端的中未包含的包 我们正在使用的新JAR缺少运行时类路径 版本与以前的JAR冲突 当我今天遇到这些问题时,我会采取跟踪和错误的方法来使事情正常工作。我需要更多的
问题内容: 在此示例中: 无法编译为: 而被编译器接受。 这个答案说明唯一的区别是,与不同,它允许您稍后引用类型,似乎并非如此。 是什么区别,并在这种情况下,为什么不第一编译? 问题答案: 通过使用以下签名定义方法: 并像这样调用它: 在jls§8.1.2中,我们发现(有趣的部分被我加粗了): 通用类声明定义了一组参数化类型(第4.5节), 每种可能通过类型arguments调用类型参数节的类型
问题内容: 今天,我按照一些说明在Linux中安装软件。有一个脚本需要首先运行。它设置一些环境变量。 指令告诉我要执行,但是我执行错误了。因此未设置环境。最后,我注意到了这一点并继续进行。 我想知道这两种调用脚本方法的区别。我对Linux完全陌生,所以请尽可能详细。 问题答案: 运行脚本,将启动一个新的运行脚本的外壳。新的外壳程序不会影响启动脚本的父外壳程序。 是的简写形式,它将在当前shell中