背景
测试环境在启动tomcat时,报错java.lang.NoClassDefFoundError: cn/lys/outerclass/AnonymousTest$1
很明显,AnonymousTest$1这个类找不到。服务器中确实不存在,但是在我本地编译的class文件中是存在的。
该类内容很简单,一下代码仅测试用:
package cn.lys.outerclass;
public class AnonymousTest {
public static void init() {
new InnerClass().f();
}
private static class InnerClass {
void f() {
System.out.println(1);
}
}
}
现象
这个类我同事最近维护过一次,使用的IDEA工具,服务器使用的ECJ(Eclipse Compiler for Java)编译。由于同事修改了该类,需要替换服务器class文件。但是,替换完成后,报上述错误。
原因
服务器配置的编译器是是ECJ,该类编译只有2个class文件:
AnonymousTest$InnerClass.class
AnonymousTest.class
同事使用IDEA,默认是javac编译器,编译出3个class文件:
AnonymousTest$1.class
AnonymousTest$InnerClass.class
AnonymousTest.class
只替换了AnonymousTest.class一个文件,导致报错。
总结
以前没有注意到编译器对class的影响,是一个知识盲点。替换class文件需要替换一整套,需要替换的文件如果较多(大于5个),建议直接打整个war包更新,并备份服务器项目!