J'ai vérifié les questions liées à cette erreur, mais je n'ai pas trouvé la réponse. J'ai le code suivant. L'erreur est liée à appeler la méthode jLog et si je prends l'erreur est parti, donc je ne comprends pas ce qui est des problèmes - que ma première expérience avec JNI:JNI - ERREUR FATALE dans la méthode native: Mauvaise référence globale ou locale passée à JNI
static jclass util_class;
static jmethodID log_from_jni;
...
util_class = (*env)->FindClass(env, "package/Util");
if ((*env)->ExceptionOccurred(env)) {
printf("Error occured when loading Util class\n");
}
log_from_jni = (*env)->GetStaticMethodID(env, util_class,
"logFromJNI", "(Ljava/lang/String;)V");
if ((*env)->ExceptionOccurred(env)) {
printf("Error occured when loading logFromJNI method\n");
}
...
void jLog(JNIEnv *env, char* cstr) {
if (util_class != NULL || log_from_jni != NULL) {
jstring str = (*env)->NewStringUTF(env, cstr);
(*env)->CallStaticVoidMethod(env, util_class, log_from_jni, str);
} else {
printf(cstr);
}
}
JNIEXPORT void JNICALL Java_package_callLog(JNIEnv * env, jobject obj) {\
jLog(env, "JNI: Log");//
}
Merci.
Je suppose que 'package.Util' est une faute de frappe pour' package/Util'? –
oui, c'était une faute de frappe. désolé à ce sujet – xtcr1st1