ECJ与javac编译内部类问题

背景

测试环境在启动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包更新,并备份服务器项目!

你可能感兴趣的:(遇到的问题)