我有一个带有 Java 基础 Activity、Java JNI 接口类和本机代码的 Android 项目。我有合适的
System.loadlibrary(_libraryname_);
在我的 Java 接口类和 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 函数。我已经尝试卸载该应用程序并重新安装它,但它永远不会运行。