从 JNI 调用 Java 方法导致程序崩溃

Calling Java Methods from JNI results in program crash

调用 get 或 set 方法崩溃。对象数组有效。它打印到 2.Intially 行在插入 jobjectArray 时出现错误。还尝试从 Jobject 获取值。getter 和设置器都失败了。

JNI代码如下:

JNIEXPORT jint JNICALL Java_demo_JNIWrapper_pax_1store_1get_1data_1avail_1info
  (JNIEnv *env, jclass jclass1, jobjectArray jobj)

{

.....
.....

     int len = (*env)->GetArrayLength(env, jobj);

    printf ("Incoming object array length = %d\n", len);// - - - > Works.. shows 2 (I am passing 2 objects)

    jobject j = (*env)->GetObjectArrayElement(env, jobj,0);
        printf("This line 1 \n ");
       jmethodID meth1=(*env)->GetMethodID(env,jclass1,"getTimestamp","()Ljava/lang/String;");
printf("This line 2 \n ");    // - - - - > Works.. 

        jstring string_from_obj = (*env)->CallObjectMethod(env,j,meth1);   // - - - - > Crashes..
printf("This line 3 \n ");    // - - -> does not print this..
        printf("Contents are =%s\n",(*env)->GetStringUTFChars(env, string_from_obj, 0)); 

............

}       

我的Java对象如下:

public class DataAvailable {
String timestamp;
public String getTimestamp() {
    return timestamp;
}
public void setTimestamp(String timestamp) {
    this.timestamp = timestamp;
}
}

调用 JNI 如下:

public native int pax_store_get_data_avail_info(DataAvailable[] stats_array);

明显的问题是 pax_store_get_data_avail_info() 不是 DataAvailable 的方法。是其他一些class的方法吗?你实际上并没有说它是什么。但我们假设它是:

class X {
   public native int pax_store_get_data_avail_info(DataAvailable[] stats_array);
}

当您调用此方法时,您获得的 jclass jclass1 参数是针对 "X",而不是针对 DataAvailable。因此,您对 GetMethodID() 的调用可能会失败。您没有检查 return,因此您可能将错误的方法 ID 传递给下一个调用。 JNI 失败是严重的崩溃,而且非常丑陋。

您需要在 jclass 中查询 DataAvailable 并使用它。