3

我正在开发一套简单的 Java 代理来帮助我(希望其他人)对 Java 应用程序进行故障排除。我想创建的代理之一是 JComponent.getToolTipText() 方法,只需将鼠标光标悬停在它上面即可快速识别任何 GUI 类。

你可以在这里找到我的转换器的代码和项目的其余部分:

http://sfn.cvs.sourceforge.net/viewvc/sfn/core/src/main/java/org/leplus/sfn/transformer/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 类。

这是应用程序在我启动它并将鼠标放在它上面时打印的内容:

加载代理:JComponent
仪器准备就绪!
线程“AWT-EventQueue-0”中的异常 java.lang.NoClassDefFoundError: org/leplus/sfn/tracer/ComponentTracer
 在 javax.swing.JComponent.getToolTipText(JComponent.java)
 在 javax.swing.ToolTipManager$insideTimerAction.actionPerformed(ToolTipManager.java:662)
...

令我惊讶的是,如果我将转换器更改为从 JRE 调用任何类,它就可以工作。但是当我调用我自己的类 org.leplus.sfn.tracer.ComponentTracer 时它不起作用。我的第一个猜测是类路径问题,但 ComponentTracer 既在类路径中,也在代理的 jar 中。所以我迷路了。

如果你们中的任何人看到我遗漏了什么。

干杯,

汤姆

4

2 回答 2

8

这是一个类加载器问题。您正在检测由引导类加载器管理的类 (javax.swing.JComponent),并让它引用由系统类加载器管理的类 (org.leplus.sfn.tracer.ComponentTracer)。

如果将 ComponentTracer 类放在引导类加载器中,问题应该会消失。

java -Xbootclasspath/p:<path/to/jar/containing/ComponentTracer> -javaagent:...
于 2011-01-02T03:59:08.557 回答
0

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

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

于 2011-01-02T01:48:37.620 回答