命令行 Java:错误:发生 JNI 错误/线程“main”中出现异常 java.lang.NoClassDefFoundError

命令行 Java:错误:发生 JNI 错误/线程“main”中出现异常 java.lang.NoClassDefFoundError

我正在尝试编译/构建/运行Java 项目首次在 Ubuntu 14.04 上运行。该项目依赖于 CPlex 优化库。我使用以下代码编译了代码:

javac -classpath .:/opt/ibm/ILOG/CPLEX_Studio_Community128/cplex/lib/cplex.jar ./bendersexample/*.java

然后我创建了一个清单文件 MANIFEST.MF,它如下所示:

Manifest-Version: 1.0
Main-Class: bendersexample.Demo

然后我像这样创建了.jar:

jar -cfm example.jar MANIFEST.MF ./bendersexample/*.class

我想通过运行以下命令来执行我的代码:

java -Djava.library.path=/opt/ibm/ILOG/CPLEX_Studio_Community128/cplex/bin  -jar example.jar

但是,我收到以下错误:

Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.NoClassDefFoundError: ilog/concert/IloException
    at java.lang.Class.getDeclaredMethods0(Native Method)
    at java.lang.Class.privateGetDeclaredMethods(Class.java:2701)
    at java.lang.Class.privateGetMethodRecursive(Class.java:3048)
    at java.lang.Class.getMethod0(Class.java:3018)
    at java.lang.Class.getMethod(Class.java:1784)
    at sun.launcher.LauncherHelper.validateMainClass(LauncherHelper.java:544)
    at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:526)
Caused by: java.lang.ClassNotFoundException: ilog.concert.IloException
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:338)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 7 more

实际上,当我运行

java -jar example.jar

所以我认为问题与 Java 无法找到库有关?我 100% 确定给出的路径是 CPlex 的安装位置。

java -version返回

java version "1.8.0_161"
Java(TM) SE Runtime Environment (build 1.8.0_161-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.161-b12, mixed mode)

javac -version返回

javac 1.8.0_161

答案1

我查看了 .jar 文件的内容,其中 Main 类被列为bendersexample.Demo。我在 /bendersexample 目录中创建并运行该 jar。

对我来说,解决方案只是将 Manifest 和 jar 文件移动到父目录。

将来遇到此类问题的人都应该在尝试其他任何方法之前先查看一下他们的项目文件结构,因为事实证明这是一个非常容易的解决方法!

相关内容