一 知识准备
NoClassDefFoundError:正如它们的名字所说明的是一个错误 (Error),而ClassNotFoundException是一个异常。正如上一章节所说Exception和Error是Thorwable下的两个不同的子
类。在Java中错误和异常是有区别的,我们可以从异常中恢复程序但却不应该尝试从错误中恢复程序。异常大多由于程序员编码导致,而Error多是由于JVM内部产生。
二 产生原因
ClassNotFoundException 产生原因:
1 Java支持使用反射方法来动态地加载类,任意一个类的类名如果被作为参数传递给这个方法都将导致该类被加载到JVM内存中,如果这个类在类路径中没有被找到,那么此时就会在运行时抛
出ClassNotFoundException异常。
2 ClassNotFoundException发生在装入阶段。 当应用程序试图通过类的字符串名称,使用常规的三种方法装入类,但却找不到指定名称的类定义时就抛出该异常。
NoClassDefFoundError 产生原因:
1 如果JVM或者ClassLoader实例尝试加载(可以通过正常的方法调用,也可能是使用new来创建新的对象)类的时候却找不到类的定义。要查找的类在编译的时候是存在的,运行的时候却找
不到了。这个错误往往是你使用new操作符来创建一个新的对象但却找不到该对象对应的类。这个时候就会导致NoClassDefFoundError. 由于NoClassDefFoundError是有JVM引起的,所
以不应该尝试捕捉这个错误。
2 NoClassDefFoundError: 当目前执行的类已经编译,但是找不到它的定义时也就是说你如果编译了一个类B,在类A中调用,编译完成以后,你又删除掉B,运行A的时候那么就会出现这个
错误 加载时从外存储器找不到需要的class就出现ClassNotFoundException 连接时从内存找不到需要的class就出现NoClassDefFoundError。
三 如何解决
ClassNotFoundException 解决方法
唯一需要做的就是要确保所需的类连同它依赖的包存在于类路径中。当反射调用的时候,类加载器会查找 类路
径中的类,如果找到了那么这个类就会被成功加载,如果没找到,那么就会抛出ClassNotFountException,除了 Class.forName,ClassLoader.loadClass、
ClassLOader.findSystemClass在动态加载类到内存 中的时候也可能会抛出这个异常。 另外还有一个导致ClassNotFoundException的原因就是:当一个类已经某个类加载器加载到内存中
了,此时另一个类加载器又尝试着动态地 从同一个包中加载这个类。 由于类的动态加载在某种程度上是被开发者所控制的,所以他可以选择catch这个异常然后采取相应的补救措施。有些程序
可能希望忽略这个异常而采取其他方法。还有一些程序则会终止程序然后让用户再次尝试前做点事情。
NoClassDefFoundError 解决方法:
解决这个问题的办法就是:查找那些在开发期间存在于类路径下但在运行期间却不在类路径下的类。
1. 首先是类在运行的时候依赖于其它的一个jar包,但是该jar包没有加载到classpath中或者是该jar包的名字被其他人改了,就像我的一个例子 tibo.jar改为了tibco_v3.jar…….
2. 运行的类不在classpath中,这个问题没有一个确定的方法去知道,但是很多时候你可以通过 System.getproperty(”java.classpath“)方法,该方法能让你至少可以领略到实际存在的运
行期间的classpath。
3. 试着通过-classpath命令明确指出你认为正确的 classpath,如果能够正常执行的话就说明你使用的classpath是正确的,而系统中的 classpath已经被修该过了。
参考:http://zhidao.baidu.com/link?url=pZbWMtFOJgQzukTd5JmYC7omKndctDAz-Oa6If_ssFgVKhaFruE3BqKOltCWVa2u7KuZGgCeqmbuEklnesfJjXZ2U89aJHNtjBgYEBfSbEa