我现在被这个问题困扰了大约10小时。
mvn clean compile install
很好地编译了代码。当我试图运行绑定的JAR时,问题就出现了,这个JAR构建来包含所有的依赖项。FYI,它也是在Eclipse中运行项目时发生的。
我尝试使用-verbose:class
作为VM args,同时通过java jar
和Eclipse运行它。输出显示JVM加载“but”类,但我仍然得到异常。
还尝试了许多其他选项,比如将SWT本机库提取到与JAR相同的路径,但这也不起作用。清理我的m2缓存的相关部分没有帮助。我还仔细检查了捆绑的罐子,找出了丢失的类,你猜怎么着?就在那儿。
正如大多数人可能已经理解的那样,这是一个大得多的项目的一部分,为这个项目创建一个小的测试用例是不容易的。我尝试创建一个小示例(没有maven),它正在工作。另一个(可能)相关信息是,我在同一个类中同时使用SWT和JavaFX,下面是关于如何混合它们的工作菜谱。我正在使用Oracle JDK 1.7。
更新:到目前为止,试图将“小示例”移动到Maven,并且运行良好。我认为这个问题与maven依赖或其他什么无关。
更新:I成功地创建了一个具有相同问题的小项目。这是一个Eclipse项目,但是没有IDE应该很容易运行(因为它是一个Maven项目)。它依赖于Linux x64版本的SWT,但您也可以更改这种依赖。拜托,去https://dl.dropboxusercontent.com/u/5319290/swtjfx.tar.gz看看吧
异常堆栈跟踪:
Exception in thread "main"
java.lang.NoClassDefFoundError: org/eclipse/swt/widgets/Canvas
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClass(ClassLoader.java:800)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:449)
at java.net.URLClassLoader.access$100(URLClassLoader.java:71)
at java.net.URLClassLoader$1.run(URLClassLoader.java:361)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
at java.lang.ClassLoader.loadClass(ClassLoader.java:412)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
at java.lang.Class.getDeclaredMethods0(Native Method)
at java.lang.Class.privateGetDeclaredMethods(Class.java:2531)
at java.lang.Class.getMethod0(Class.java:2774)
at java.lang.Class.getMethod(Class.java:1663)
at sun.launcher.LauncherHelper.getMainMethod(LauncherHelper.java:494)
at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:486)
[Loaded java.util.Objects from /usr/lib/jvm/java-7-oracle/jre/lib/rt.jar]
Caused by: java.lang.ClassNotFoundException: org.eclipse.swt.widgets.Canvas
at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
... 19 more
-verbose:class
输出:
...
[Loaded org.eclipse.swt.widgets.Layout from file:/home/me/myapp-jar-with-dependencies.jar]
[Loaded org.eclipse.swt.layout.FillLayout from file:/home/me/myapp-jar-with-dependencies.jar]
[Loaded org.eclipse.swt.graphics.Drawable from file:/home/me/myapp-jar-with-dependencies.jar]
[Loaded org.eclipse.swt.widgets.Widget from file:/home/me/myapp-jar-with-dependencies.jar]
[Loaded org.eclipse.swt.widgets.Control from file:/home/me/myapp-jar-with-dependencies.jar]
[Loaded org.eclipse.swt.widgets.Scrollable from file:/home/me/myapp-jar-with-dependencies.jar]
[Loaded org.eclipse.swt.widgets.Composite from file:/home/me/myapp-jar-with-dependencies.jar]
[Loaded org.eclipse.swt.widgets.Canvas from file:/home/me/myapp-jar-with-dependencies.jar]
[Loaded org.eclipse.swt.widgets.Decorations from file:/home/me/myapp-jar-with-dependencies.jar]
[Loaded org.eclipse.swt.widgets.Shell from file:/home/me/myapp-jar-with-dependencies.jar]
[Loaded java.lang.ClassFormatError from /usr/lib/jvm/java-7-oracle/jre/lib/rt.jar]
[Loaded java.lang.NoSuchMethodException from /usr/lib/jvm/java-7-oracle/jre/lib/rt.jar]
[Loaded java.lang.Throwable$PrintStreamOrWriter from /usr/lib/jvm/java-7-oracle/jre/lib/rt.jar]
[Loaded java.lang.Throwable$WrappedPrintStream from /usr/lib/jvm/java-7-oracle/jre/lib/rt.jar]
[Loaded java.util.IdentityHashMap from /usr/lib/jvm/java-7-oracle/jre/lib/rt.jar]
[Loaded java.util.IdentityHashMap$KeySet from /usr/lib/jvm/java-7-oracle/jre/lib/rt.jar]
[Loaded java.util.Objects from /usr/lib/jvm/java-7-oracle/jre/lib/rt.jar]
[Loaded java.lang.Shutdown from /usr/lib/jvm/java-7-oracle/jre/lib/rt.jar]
[Loaded java.lang.Shutdown$Lock from /usr/lib/jvm/java-7-oracle/jre/lib/rt.jar]
我的POM的相关部分:
<repositories>
...
<repository>
<id>swt-repo</id>
<url>https://swt-repo.googlecode.com/svn/repo/</url>
</repository>
</repositories>
...
<dependencies>
...
<dependency>
<groupId>org.eclipse.swt</groupId>
<artifactId>org.eclipse.swt.gtk.linux.x86_64</artifactId>
<version>4.3</version>
</dependency>
</dependencies>
有线索吗?如果需要更多的信息,请随时向我索取。
谢谢你的帮助。
发布于 2013-11-27 08:41:21
毕竟,这是一个类加载依赖问题。JavaFX FXCanvas
是在SWT类之前加载的。
解决方案是在运行绑定JAR时使用-Xbootclasspath/a
将特定于SWT平台的JAR添加到引导路径。
此将SWT附加到引导路径,使其在需要时可供JavaFX类使用。
注意:如果您需要,也可以对大多数IDE运行/调试信任进行调整。
https://stackoverflow.com/questions/19969637
复制相似问题