我想在Java代码中使用C ++方法。因此,我决定使用JNI。但是由于执行No implementation found for void com.me.Native.helloWorld() (tried Java_com_me_Native_helloWorld and Java_com_me_Native_helloWorld__)
Native.java (在其他地方称为Native.helloWorld()
):
package com.me;
public class Native{
static {
System.loadLibrary("detection_based_tracker");
}
public static native void helloWorld();
}
Android.mk :
...
LOCAL_SRC_FILES += com_me_Native.cpp
LOCAL_C_INCLUDES += $(LOCAL_PATH)
LOCAL_MODULE := detection_based_tracker
include $(BUILD_SHARED_LIBRARY)
com_me_Native.h (使用javah命令生成):
/* DO NOT EDIT THIS FILE - it is machine generated */
#include <jni.h>
/* Header for class com_me_Native */
#ifndef _Included_com_me_Native
#define _Included_com_me_Native
#ifdef __cplusplus
extern "C" {
#endif
/*
* Class: com_me_Native
* Method: helloWorld
* Signature: ()V
*/
JNIEXPORT void JNICALL Java_com_me_Native_helloWorld
(JNIEnv *, jclass);
#ifdef __cplusplus
}
#endif
#endif
com_me_Native.cpp :
#include <com_me_Native.h>
#include <iostream>
#include <android/log.h>
#define LOG_TAG "HelloWorld"
#define LOGD(...) ((void)__android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__))
#ifdef __cplusplus
extern "C" {
#endif
using namespace std;
/*
* Class: com_me_Native
* Method: helloWorld
* Signature: ()V
*/
JNIEXPORT void JNICALL Java_com_me_Native_helloWorld
(JNIEnv *, jclass)
{
LOGD("Hello from c++");
}
#ifdef __cplusplus
}
#endif
您看到我的方法上使用了JNIEXPORT
和JNICALL
。我也将extern "C"
用于C ++。我的.h
由javah
生成。我检查了Android.mk
,但没有忘记将.cpp
文件添加到LOCAL_SRC_FILES
。我将库静态加载到Native.java
中以使用我的静态函数。
现在我不知道错误可能来自何处...知道吗?!
答案 0 :(得分:0)
包含保护只能在.h
文件中,而不能在.cpp
文件中。
因此,在您的.cpp
文件中,删除以下几行:
#ifndef _Included_com_me_Native
#define _Included_com_me_Native
以及最后的#endif
。
当前代码会发生什么,就是当您包含头文件时会定义_Included_com_me_Native
,因此#ifndef _Included_com_me_Native
文件中的.cpp
将为false,并且这些代码均不会被编译。