加载JNI库时出现不满意的链接错误

时间:2015-09-29 19:54:41

标签: java c macos java-native-interface

我正在编写一个简单的Hello World Java程序来调用本机库中的代码。但是,当我运行该程序时,我收到以下错误:

 Exception in thread "main" java.lang.UnsatisfiedLinkError: no TestJNI in java.library.path
    at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1764)
    at java.lang.Runtime.loadLibrary0(Runtime.java:823)
    at java.lang.System.loadLibrary(System.java:1044)
    at TestJNI.<clinit>(TestJNI.java:4)

以下是代码:
爪哇:

//filename: TestJNI.java

public class TestJNI{

    static{
        System.loadLibrary("TestJNI");
    }   

    private native void helloWorld();

    public static void main(String[] args){
        new TestJNI().helloWorld();
   }
}

C:

//filname:TestJNI.c

#include <jni.h>
#include <stdio.h>
#include "TestJNI.h"

JNIEXPORT void JNICALL Java_TestJNI_helloWorld(JNIEnv *env, jobject thisObj){
    printf("Hello World!\n");
    return;
}

使用以下编译器,标志和参数编译C文件:
clang -o TestJNI.jnilib -I/System/Library/Frameworks/JavaVM.framework/Headers -lc -shared TestJNI.c
然后Java应用程序运行如下:
java -Djava.library.path=. TestJNI

我正在Mac OS X Yosemite上编译和运行这些文件。有谁知道我做错了什么?

2 个答案:

答案 0 :(得分:1)

验证java.library.path变量是否指向包含TestJNI库的目录。 你可以尝试

System.setProperty("java.library.path", "...directory path...");

或者,使用System.load("...full path to TestJNI...");获取库的完整路径(包括文件扩展名)。 (System.loadLibrary推断我相信的文件扩展名

答案 1 :(得分:0)

您的库应该被命名为.so,以便它可以作为共享库加载。我相信您的编译行应该类似于:

clang -shared -undefined dynamic_lookup -o TestJNI.so -I / System / Library / Frameworks / JavaVM.framework / Headers -lc TestJNI.c