我有一个带有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 之间有一个下划线/_

10-08 12:54