关于: Could not initialize class xxx错误的原因和处理办法

时间:2025-04-01 15:41:44

关于NoClassDefFoundError错误出现的原因有多种,网上其他博主也给出各种答案,但说的都比较广泛。
这里博主说一下由于初始化失败而造成的NoClassDefFoundError错误。
博主在一个Test这个类中使用了静态代码块,类结构如下所示:

public class Test {

	private static int i = 0;

	static {
		//放一个除0操作,使类初始化失败
		i = 3/0;
	}

	public static int getI(){
		return i;
	}
}

这样在类初始化时会由于除0异常而使类初始化失败;
下面这段代码会调用()方法:

	@PostMapping("/connectionTimeOutTest")
	public ResponseEntity connectionTimeOutTest(){
		return ResponseEntity.ok(Test.getI());
	}

当第一次调用的时候,会使得Test类的静态代码块执行,此时会报除0异常,

java.lang.ArithmeticException: / by zero
	at com.example.miaosha.bean.Test.<clinit>(Test.java:14) ~[classes/:na]
	at com.example.miaosha.web.UnionTestResource.connectionTimeOutTest(UnionTestResource.java:23) ~[classes/:na]
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_181]
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_181]

而第二次调用的时候就会因为初始化失败而报NoClassDefFoundError错误了
第二次调用:

java.lang.NoClassDefFoundError: Could not initialize class com.example.miaosha.bean.Test
	at com.example.miaosha.web.UnionTestResource.connectionTimeOutTest(UnionTestResource.java:23) ~[classes/:na]
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_181]
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_181]
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_181]

当出现NoClassDefFoundError错误时可以检查一下是不是类的初始化出现了问题。