线程“main”java.lang.UnsatisfiedLinkError中的异常

时间:2013-07-30 17:52:51

标签: java c++ dll java-native-interface

我在Java中测试JNI时出现以下显式错误:

Exception in thread "main" java.lang.UnsatisfiedLinkError: Italk2learn.hello()V
    at Italk2learn.hello(Native Method)
    at Italk2learn.main(Italk2learn.java:10)

dll或路径没有问题,因为我的java类的静态代码运行良好:

static {
        try {
            System.loadLibrary("Italk2learn");
        } catch (Exception e) {
            System.err.println(e);
            System.exit(1);
        }
    }

而且我认为图书馆很好。

我使用JVM 32位编译并获取C ++标头(javah)和MinGW32 for C ++。在这两种情况下,我都使用eclipse进行C ++和Java。

这是我的代码:

爪哇:

public class Italk2learn {

    public native void hello();

    public static void main(String[] args) {
        System.out.println("Hello World Java!");
        try {
            new Italk2learn().hello();
        } catch (Exception e) {
            System.err.println(e);
            System.exit(1);
        }
    }
    static {
        try {
            System.loadLibrary("Italk2learn");
        } catch (Exception e) {
            System.err.println(e);
            System.exit(1);
        }
    }
}

C ++:

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

JNIEXPORT void JNICALL Java_Italk2learn_hello(JNIEnv *, jobject) {
    printf("Hello World C++!\n");
#ifdef __cplusplus
    printf("__cplusplus is defined\n");
#else
    printf("__cplusplus is NOT defined\n");
#endif
    return;
}

2 个答案:

答案 0 :(得分:3)

我找到了答案!似乎在Windows中使用JNI时,它会查找以_Java_开头的函数,而在其他所有平台中查找Java_。为什么会出现这种情况,而不是写在我不知道的文档中,但它会使一切工作完美!

当javah创建头文件时,每个函数都被命名为Java_package_Class_method。奇怪的是,当这样编译时,JNI找不到本机方法的正确函数并吐出错误,但如果在Java之前添加了下划线,那么JNI就能找到该函数。

答案 1 :(得分:2)

如果您正在使用C ++进行编译,则必须使用extern "C"包装JNI方法,以确保编译器不应用自己的修改:

extern "C" {
    JNIEXPORT void JNICALL Java_Italk2learn_hello(JNIEnv *, jobject) {
        // ..
    }
}

请参阅:http://docs.oracle.com/javase/6/docs/technotes/guides/jni/spec/design.html#wp224