我在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;
}
答案 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