在运行时重新定义嵌套类,是否可能? (java.lang.NoClassDefFoundError:类名不匹配)

时间:2015-06-24 09:41:14

标签: java nested-class redefinition

我有一个名为" InnerClassTransactionServlet"的测试类,在该类中我定义了一个名为RandomResultHandler的内部类(InnerClassTransactionServlet $ RandomResultHandler)。

我正在尝试动态地重新定义内部类,但是仪器正在返回"类名不匹配"错误:

java.lang.NoClassDefFoundError: class names don't match
    at sun.instrument.InstrumentationImpl.redefineClasses0(Native Method)
    at sun.instrument.InstrumentationImpl.redefineClasses(InstrumentationImpl.java:170)
    at com.example.Test.redefineClass(Test.java:33)
    .
    .
    .

我试图重新定义封闭类但我收到同样的错误。

负责重新定义的方法非常简单:

public static void redefineClass(ClassDefinition definition) throws ClassNotFoundException, UnmodifiableClassException{
        log.debug("Trying to redefine class "+definition.getDefinitionClass().getName());
        Agent.getInstrumentation().redefineClasses(definition);
}

"定义"参数只是一个ClassDefinition对象,使用类名和编译的字节结果定义:

log.debug("Class "+clazz.getName()+" compiled properly. Trying to replace the bytecode in memory.");
ClassDefinition cd = new ClassDefinition(clazz, compilationResult);
redefineClass(cd);

使用完全相同的代码重新定义非嵌套类(或没有嵌套类的类),它可以正常工作。

您是否知道是否可以重新定义包含嵌套类的嵌套类或类?

谢谢!

1 个答案:

答案 0 :(得分:2)

最后,我能够找到问题:)

有必要在封闭类的同时重新定义嵌套类。只能重新定义嵌套类。

所以,我已经改变了我的重定义方法以接收多个ClassDefinition对象:

public static void redefineClasses(ClassDefinition... definition) throws ClassNotFoundException, UnmodifiableClassException{
        StringBuffer sb = new StringBuffer();
        for (int i = 0; i < definition.length; i++) {
            if ( sb.length() > 0 )
                sb.append(", ");
            sb.append(definition[i].getDefinitionClass().getName());
        }

        log.debug("Trying to redefine class"+(definition.length>1?"es ":" ")+sb);
        Agent.getInstrumentation().redefineClasses(definition);
    }

所以,现在为了重新定义我的内部类,我使用&#34; InnerClassTransactionServlet&#34;的类定义调用该方法。和&#34; InnerClassTransactionServlet $ RandomResultHandler&#34;并且代码被正确替换。