这个问题的解决手段是,你需要在将JNI方法名称实际传递给C++代码之前将名称转换为JNI可识别的名称。 在C++代码中使用该名称时,您需要将其转换回原始名称。
以下是示例代码:
在Java代码中,你需要这样做:
public native void foo(int x);
然后在C++中,你需要这样做:
JNIEXPORT void JNICALL Java_com_example_foo(JNIEnv * env, jobject obj, jint x) { jclass clazz = env->GetObjectClass(obj); jmethodID mid = env->GetMethodID(clazz, "foo", "(I)V"); env->CallVoidMethod(obj, mid, x); }
在这个示例中,我们使用Java_com_example_foo作为JNI函数的名称,因此我们需要将foo转换为Java_com_example_foo。
同样的,如果你需要在C++代码中使用invoke函数,你需要将其转换为JNI的命名规范:
jclass clazz = env->FindClass("java/lang/reflect/Method"); jmethodID invokeID = env->GetMethodID(clazz, "invoke", "(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;");
在这个示例中,我们使用invoke作为JNI函数的名称,因此我们需要将其转换为JNI命名规范。
这样做应该能解决引用“invoke”未解决的问题。