在Java中使用外部库

时间:2013-10-01 10:41:51

标签: java ant native

这是我在运行时得到的错误:

[java] Exception in thread "main" java.lang.NoClassDefFoundError: org/lwjgl/LWJGLException

注意,这是运行时错误,而不是编译时错误。我的build.xml中的两个任务都具有相同的类路径集,并且每次编译任务都运行良好:

<path id="classpath">
    <fileset dir="lib" includes="*.jar" />
</path>

<target name="compile">
    <mkdir dir="build/classes"/>
    <javac
        srcdir="src"
        classpathref="classpath"
        includeantruntime="false"
        destdir="build/classes"
    />
</target>
...
<target name="run" depends="clean,compile,jar">
    <java
        jar="build/jar/${project.name}.jar"
        fork="true"
        classpathref="classpath"
        >
        <sysproperty key="java.library.path" path="${path.lib}/windows"/>
    </java>
</target>

尝试通过命令行手动运行jar会产生相同的结果:

java -cp .:lib/*.jar -Djava.library.path=lib/windows -jar build/jar/JUtopia.jar
Exception in thread "main" java.lang.NoClassDefFoundError: org/lwjgl/LWJGLException

请注意库jar文件正常:

bash-3.1$ jar -tf lib/lwjgl.jar | grep LWJGLException
org/lwjgl/LWJGLException.class

本地图书馆已经到位:

bash-3.1$ ls lib/windows/lwjgl.dll
lib/windows/lwjgl.dll

问题:火灾发生在哪里我出错了?我已经在这个问题上打了将近3天。任何帮助将不胜感激。

完整结果堆栈:

clean:
   [delete] Deleting directory C:\Users\mkumpan\Projects\JUtopia\build

compile:
    [mkdir] Created dir: C:\Users\mkumpan\Projects\JUtopia\build\classes
    [javac] Compiling 12 source files to C:\Users\mkumpan\Projects\JUtopia\build\classes

jar:
    [mkdir] Created dir: C:\Users\mkumpan\Projects\JUtopia\build\jar
      [jar] Building jar: C:\Users\mkumpan\Projects\JUtopia\build\jar\JUtopia.jar

run:
     [java] Exception in thread "main" java.lang.NoClassDefFoundError: org/lwjgl/LWJGLException
     [java]     at JUtopia.<init>(Unknown Source)
     [java]     at JUtopia.main(Unknown Source)
     [java] Caused by: java.lang.ClassNotFoundException: org.lwjgl.LWJGLException
     [java]     at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
     [java]     at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
     [java]     at java.security.AccessController.doPrivileged(Native Method)
     [java]     at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
     [java]     at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
     [java]     at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
     [java]     at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
     [java]     ... 2 more

P.S。:注意,我在Windows环境中使用Console2和bash进行命令行工作,因此windows natives还有linux shell语法。使用vanilla cmd运行jar会产生相同的结果。

2 个答案:

答案 0 :(得分:1)

-jar...

When you use this option, the JAR file is the source of all user classes, and other user class path settings are ignored. - reference

尝试setting the Class-Path in the JAR

或者尝试在没有-Jar选项的情况下运行,方法是在命令行上指定主类

答案 1 :(得分:0)

可能的原因之一是在加载类LWJGLException时它还引用了在类路径中找不到的另一个类。因此,报告的错误有时不明确。

重要的是你有这个NoClassDefFoundError而不是ClassNotFoundException这是你认为你有的错误:它找不到类LWHLException,是的它可以!但它无法载入它......