10

我有 JNI 方法,我试图在其中调用 Java 方法。这是我的 JNI 代码

void DummySink::afterGettingFrame(unsigned frameSize, unsigned numTruncatedBytes,
                  struct timeval presentationTime, unsigned /*durationInMicroseconds*/) {

     __android_log_print(ANDROID_LOG_VERBOSE, "RTSP", "Frame: %c", propRec->sPropBytes);
     jmethodID mid;
     jclass handlerClass = env9->FindClass("ob/android/Stream");
     if (handlerClass == NULL) {
         __android_log_print(ANDROID_LOG_VERBOSE, "RTSP-Error", "Class");
     }
     mid = env9->GetMethodID(handlerClass, "onResponse", "([B)V");
     if (mid == NULL) {
         __android_log_print(ANDROID_LOG_VERBOSE, "RTSP-Error", "Method");
     }

     jbyteArray jbArray = env9->NewByteArray((int)propRec->sPropLength);
     env9->SetByteArrayRegion(jbArray, 0, (int)propRec->sPropLength, (jbyte*)propRec->sPropBytes);

     //jobject theClass = env9->FindClass("ob/android/Stream");

     env9->CallVoidMethod(handlerClass, mid, jbArray);

}

这是我拥有的Java代码

public void onResponse(byte[] str) 
    { 
        Log.v("Response", "Java");
    }

我收到以下崩溃

03-08 16:01:05.915: W/dalvikvm(17552): JNI WARNING: can't call Lob/android/Stream;.onResponse on instance of Ljava/lang/Class;
03-08 16:01:05.915: W/dalvikvm(17552):              in Lob/android/Stream;.stream:()V (CallVoidMethodV)

应用 Mah 的答案后,这是我收到的异常

03-08 16:40:20.646: W/dalvikvm(4076): JNI WARNING: JNI method called with exception pending
03-08 16:40:20.646: W/dalvikvm(4076):              in Lob/android/Stream;.stream:()V (NewByteArray)
03-08 16:40:20.646: W/dalvikvm(4076): Pending exception is:
03-08 16:40:20.646: I/dalvikvm(4076): java.lang.NoSuchMethodError: no method with name='onResponse' signature='([B)V' in class Lob/android/Stream;
03-08 16:40:20.646: I/dalvikvm(4076):   at ob.android.Stream.stream(Native Method)
03-08 16:40:20.646: I/dalvikvm(4076):   at ob.android.Stream.<init>(Stream.java:28)
03-08 16:40:20.654: I/dalvikvm(4076):   at ob.android.MainActivity.startRecording(MainActivity.java:203)

现在 onResponse 方法是静态的。

4

2 回答 2

11

您的 Java 方法是一个实例方法(不是静态的),但您的本机代码并未引用ob.android.Stream要调用onResponse()的任何特定实例。

调用时CallVoidMethod(),第一个参数是您正在运行该方法的实例(对象),而不是类本身。如果您使用CallStaticVoidMethod().

于 2013-03-08T11:11:56.913 回答
0

我想为 NoSuchMethodError 问题再添加一个解决方案,虽然这里可能不是这种情况,但可能会为你们中的一些人节省大量的调试时间。

对我来说,有一个我必须编辑的 proguard 配置文件。否则,所有未在 java 代码中调用的非静态 java 方法都将被优化,并且本机 C++ 代码无法找到它们。

于 2017-08-28T13:33:03.900 回答