无法在JNI项目中加载.so



我已经阅读了许多类似的问题,但仍然对这个项目感到困惑。我正在Ubuntu 11.04 64位上使用Eclipse尝试一个非常简单的JNI项目。

我已经正确地构建了.so文件。我之所以知道这一点,是因为当我从Java程序中使用System.load("/accept/path/to/my/libcproject.so")时,我可以调用它。但是,当我尝试使用System.loadLibrary("libcproject")时,我得到了一个不满意的链接错误。

这是我的简单Java程序:

package pkg;
public class MyClass {
static {
    System.out.println("java.library.path: " + System.getProperty("java.library.path"));
    System.loadLibrary("libcproject");
}
private native String foo(String input);
public static void main(String[] args) {
    MyClass mc = new MyClass();
    String output = mc.foo("input");
    System.out.println(output);
}
}

正如你所看到的,我正在打印java.library.path是什么。当我运行程序时,我得到:

java.library.path: /usr/lib/jvm/java-6-sun-1.6.0.26/jre/lib/amd64/server:/usr/lib/jvm/java-6-sun-1.6.0.26/jre/lib/amd64:/usr/lib/jvm/java-6-sun-1.6.0.26/jre/../lib/amd64:/home/mlevin/workspace/cproject/Debug:/usr/java/packages/lib/amd64:/usr/lib64:/lib64:/lib:/usr/lib
input

"input"是我的C函数返回的内容(它只是把你给它的东西还给你)。

如果我将System.load调用更改为System.loadLibrary("libcproject"),我会得到不满意的链接错误,尽管正如您从输出中看到的,/home/mlevin/workspace/cproject/Debug(libcproject.so所在的位置)在java.library.path.中

java.library.path: /usr/lib/jvm/java-6-sun-1.6.0.26/jre/lib/amd64/server:/usr/lib/jvm/java-6-sun-1.6.0.26/jre/lib/amd64:/usr/lib/jvm/java-6-sun-1.6.0.26/jre/../lib/amd64:/home/mlevin/workspace/cproject/Debug:/usr/java/packages/lib/amd64:/usr/lib64:/lib64:/lib:/usr/lib
Exception in thread "main" java.lang.UnsatisfiedLinkError: no libcproject in java.library.path
at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1738)
at java.lang.Runtime.loadLibrary0(Runtime.java:823)
at java.lang.System.loadLibrary(System.java:1028)
at pkg.MyClass.<clinit>(MyClass.java:7)
Could not find the main class: pkg.MyClass.  Program will exit.

在这一点上我很困惑。有什么建议吗?

感谢

删除lib前缀,如下所示:

System.loadLibrary("cproject");

Java会自动在开头添加lib,在结尾添加.so(不管怎样,对于类Unix操作系统。在Windows上,它会在末尾添加.dll)。

.export LD_LIBRARY_PATH=。,从而为当前目录设置库路径,Java文件查找so.

最新更新