Мне нужно изменить следующий класс во время выполнения, чтобы напечатать значение переменной экземпляра «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 Класс testClass = Loader.getSystemClassLoader(). LoadClass ("test.hib.javaassist.JavaAssistTest"); \t \t JavaAssistTest test = (JavaAssistTest) testClass.newInstance(); Но никаких изменений в результатах! – Renjith
Я уверен, что не перезагрузит класс, если он уже загружен. –