Java 运行时发生 NoClassDefFoundError: Could not initialize class 的解决方法

最近遇到了如下问题:

在编译时没有异常的程序,在运行时抛出异常称 NoClassDefFoundError: Could not initialize class {类名}

根据 Java 官方文档,NoClassDefFoundError 是由于 JVM 或 ClassLoader 实例为了调用某个类的方法或 new 类的新的实例,而试图加载该类的定义时,却无法找到其定义,而抛出的异常。需要注意,对于抛出该异常的情况,试图找到的类的定义在编译时存在,只是在运行时不知所踪。

NoClassDefFoundError 总的来讲有两种情况,类文件不存在,或是类初始化错误。它们的错误信息不同。

  • 如果无法找到类文件,错误信息为 java.lang.NoClassDefFoundError: com/example/Foo
  • 如果类文件初始化错误,错误信息则如前文所提,为 NoClassDefFoundError: Could not initialize class {类名}。这通常由类的静态成员或静态初始化语句块引起。诸如 private static final MyClass val = new MyClass(); 或直接执行于 static {} 代码块中的语句抛出异常,都可能会引发 NoClassDefFoundError。针对第二种这种情况,可以在类的 static initializer 中增加 try catch 语句来捕获异常并输出日志,来了解具体错误内容。

此外还有一种相似但不同的错误,ClassNotFoundException。它通常由 Java 运行时在无法找到仅在运行过程中才需要加载的类时抛出。

可以从 Wikipedia 的 Java Classloader 条目进一步了解 classloader 的行为。

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注