我正在制作简单Java代理的套件,以帮助我(并希望其他人)对Java应用程序进行故障排除。我想创建仪器的代理之一jcomponent.getToolTipText()方法,可以通过将鼠标光标悬停在其上来快速识别任何GUI类。

您可以在此处找到我的变压器的代码和项目的其余部分:

http://sfn.cvs.sourceforge.net/viewvc/sfn/core/src/src/main/java/oorg/leplus/sfn/sfn/transformer/jcomponentformer/jcomponenttransformer.java?view==markup

我使用附件的代理商启动测试GUI如下:

$ java -javaagent:target/jars/sfn-0.1-agent.jar=JComponent -cp lib/jars/bcel-5.2.jar:target/jars/sfn-0.1-test.jar:target/jars/sfn-0.1-agent.jar org.leplus.sfn.test.Main

sfn-0.1-agent.jar包含org.leplus.sfn.transformer.jcomponenttransformer类。 sfn-0.1-test.jar包含org.leplus.sfn.test.main类。

这是应用程序启动时打印的内容,然后将鼠标放在上面:

Loading agent: JComponent
Instrumentation ready!
Exception in thread "AWT-EventQueue-0" java.lang.NoClassDefFoundError: org/leplus/sfn/tracer/ComponentTracer
 at javax.swing.JComponent.getToolTipText(JComponent.java)
 at javax.swing.ToolTipManager$insideTimerAction.actionPerformed(ToolTipManager.java:662)
...

令我惊讶的是,如果我更改我的变压器来调用JRE的任何类,则可以正常工作。但是,当我调用自己的类org.leplus.sfn.tracer.componenttracer时,它不起作用。我的第一个猜测是一个class Path问题,但是ComponentTracer既有class Pather又在代理的罐子中。所以我迷路了。

如果你们中的任何一个看到我缺少什么东西。

干杯,

汤姆

有帮助吗?

解决方案

这是集体加载程序问题。您正在启动由Bootstrap类加载程序管理的类(Javax.swing.jcomponent),并参考由系统类加载程序管理的类(org.leplus.sfn.tracer.componenttracer)。

如果将ComponentTracer类放在Bootstrap类加载程序中,则问题应该消失。

java -Xbootclasspath/p:<path/to/jar/containing/ComponentTracer> -javaagent:...

其他提示

尝试使用-ddebug运行,因为它可能会向您显示更多信息。

另外,我在这里看到目标目录。 http://sfn.cvs.sourceforge.net/viewvc/sfn/core/target/ 它包含一个类文件夹,但没有JARS文件夹?检查以确保JAR路径相对于项目根。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top