我有一个带有Java基本Activity,Java JNI接口(interface)类和 native 代码的Android项目。我有适当的
System.loadlibrary(_libraryname_);
在我的Java接口(interface)类中,并从logcat输出中:
11-29 15:11:20.737: D/dalvikvm(8940): No JNI_OnLoad found in /data/data/com.example.testjni/lib/libTestJNI.so 0x406ef030, skipping init
在我的cpp文件头中:
extern "C" {
JNIEXPORT jint JNICALL JNIOnLoad(JavaVM *, void *);
}
在cpp文件中:
JNIEXPORT jint JNICALL JNIOnLoad(JavaVM *vm, void *reserved)
{
LOGI("JNIOnLoad");
jvm = vm;
return JNI_VERSION_1_6; /* the required JNI version */
}
但是仍然永远不会调用OnLoad函数。我尝试卸载该应用程序并重新安装它,但它从未运行。
最佳答案
函数签名为JNI_OnLoad。 JNI 和 OnLoad 之间有一个下划线/_ 。