我必须在运行时修改以下类,以在每个方法的末尾打印实例变量'count'的值。使用javasssist打印实例变量
package test.hib.javaassist;
import java.io.IOException;
import javassist.CannotCompileException;
import javassist.ClassPool;
import javassist.CtClass;
import javassist.CtMethod;
import javassist.NotFoundException;
public class JavaAssistTest {
int count;
public void doSomething1(){
count++;
}
public void doSomething2(){
count++;
}
public void doSomething3(){
count++;
}
public void doSomething4(){
count++;
}
}
以下是主要的类,我试图通过javaassist的帮助来改变字节码。
package test.hib.javaassist;
import java.io.IOException;
import javassist.CannotCompileException;
import javassist.ClassPool;
import javassist.CtClass;
import javassist.CtMethod;
import javassist.NotFoundException;
public class Main {
public static void main(String[] args) throws NotFoundException, CannotCompileException, IOException {
ClassPool pool = ClassPool.getDefault();
CtClass cc = pool.get("test.hib.javaassist.JavaAssistTest");
CtMethod[] methods = cc.getDeclaredMethods();
for(CtMethod method : methods){
if(! (method.getName().equals("main"))){
method.insertAfter("{System.out.println(count);}");
//method.insertAfter("System.out.println($type);");
}
}
cc.writeFile();
System.out.println("Completed editting");
JavaAssistTest test = new JavaAssistTest();
test.doSomething1();
test.doSomething2();
test.doSomething3();
test.doSomething4();
System.out.println("Finished");
}
}
目前正在打印
Completed editting
Finished
我希望它打印
Completed editting
1
2
3
4
Finished
你能pointout在我的代码错误了吗?
我想像(只是猜测)该类已经加载,所以对.class文件的更改不会反映在当前JVM的运行时。您可以尝试重新加载班级,例如这里:http://stackoverflow.com/a/3971771/281108 –
hmm ....看起来很复杂。我尝试了加载类的不同方式。 \t \t Class testClass = Loader.getSystemClassLoader()。loadClass(“test.hib.javaassist.JavaAssistTest”); \t \t JavaAssistTest test =(JavaAssistTest)testClass.newInstance();但结果没有变化! – Renjith
我很确定,如果它已经加载,将不会重新加载类。 –