我觉得这是我应该知道的,但是 java 代理(用 -javaagent 指定)是否在单独的线程中运行?我读过Java 代理是一个可插入的库,它嵌入在 JVM 中运行并拦截类加载过程,但我想确定:它真的拦截了它们(听起来像是在另一个线程中运行并监视类加载)还是由 JVM 通知(JVM 调用它来解决类负载;它没有单独的线程)?
再一次,我觉得我应该能够弄清楚,但是对我好一点,我工作太努力了,我的大脑有点炸了:P
谢谢!
我觉得这是我应该知道的,但是 java 代理(用 -javaagent 指定)是否在单独的线程中运行?我读过Java 代理是一个可插入的库,它嵌入在 JVM 中运行并拦截类加载过程,但我想确定:它真的拦截了它们(听起来像是在另一个线程中运行并监视类加载)还是由 JVM 通知(JVM 调用它来解决类负载;它没有单独的线程)?
再一次,我觉得我应该能够弄清楚,但是对我好一点,我工作太努力了,我的大脑有点炸了:P
谢谢!
ClassFileTransformer 由 ClassLoader 调用。从您链接的文章中对变压器进行了一些修改,如下所示:
public byte[] transform(ClassLoader loader, String className,
Class redefiningClass, ProtectionDomain domain, byte[] bytes)
throws IllegalClassFormatException {
new RuntimeException("Transformer to Transform Class: " + className)
.printStackTrace(System.out);
return bytes;
}
产生这个输出:
java.lang.RuntimeException: Transformer to Transform Class: MyMain
at com.javalobby.tnt.instrument.SimpleTransformer.transform(SimpleTransformer.java:14)
at sun.instrument.TransformerManager.transform(Unknown Source)
at sun.instrument.InstrumentationImpl.transform(Unknown Source)
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(Unknown Source)
at java.lang.ClassLoader.defineClass(Unknown Source)
at java.security.SecureClassLoader.defineClass(Unknown Source)
at java.net.URLClassLoader.defineClass(Unknown Source)
at java.net.URLClassLoader.access$000(Unknown Source)
at java.net.URLClassLoader$1.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)