0

このコードでは本当に奇妙なことが起こります

    JNIEXPORT jintArray JNICALL Java_jsdr_SdrLibrary_getTunerGains
     (JNIEnv * env, jclass obj, jlong pointer) {
      rtlsdr_dev_t * dev;
      int * gains;
      jintArray ji;
      jint * buff;
      int i;
      int size;

      dev = (rtlsdr_dev_t *) pointer;
      size = rtlsdr_get_tuner_gains(dev, gains);

      if (size <= 0)
        .. throws an error, irrelevant code ..

      buff = (jint *) malloc(size * sizeof(jint));
      for (i = 0; i < size; i++) buff[i] = gains[i];

      ji = (*env)->NewIntArray(env, size);
      (*env)->SetIntArrayRegion(env, ji, 0, size, buff);
      return ji;
  }

メソッドは実際に Java で処理できる結果を返します。

  System.out.println(printArray(SdrLibrary.getTunerGains(pointer)));

printArray は単純なものです

public static String printArray(int[] arr) {
    String buff = "["+arr[0];
    for (int i = 1; i < arr.length; i++) buff+=", "+arr[i];
    return buff+"]";
}

出力は次のとおりです

[-10, 15, 40, 65, 90, 115, 140, 165, 190, 215, 240, 290, 340, 420, 430, 450, 470, 490]
#
# A fatal error has been detected by the Java Runtime Environment:
#
#  EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x6d86c2ff, pid=7160, tid=5880
#
# JRE version: 6.0_31-b05
# Java VM: Java HotSpot(TM) Client VM (20.6-b01 mixed mode, sharing windows-x86 )
# Problematic frame:
# V  [jvm.dll+0x7c2ff]
#
# An error report file with more information is saved as:
# C:\Users\Marto\workspace\JSDR\hs_err_pid7160.log
#
# If you would like to submit a bug report, please visit:
#   http://java.sun.com/webapps/bugreport/crash.jsp
#

ご覧のとおり、結果が返されますが、その直後に JM がクラッシュし、それ以上の行は実行されません。私は間違いなく助けに感謝します!ありがとうございました!

編集: rtlsdr_get_tuner_gains の呼び出しを削除し、代わりにゲイン配列を手動で初期化すると、エラーは発生しません。このメソッドは dll 内にあるため、どうにかして JNI をクラッシュさせないようにすることはできますか?

4

1 に答える 1

2

エラーの原因を発見しました。元のライブラリは、渡されるバッファを割り当てていないことが判明し、JNI によって保持されていないメモリが上書きされます (実際にライブラリのソースを調べる簡単なアイデアを提供してくれた QuantumMechanic に感謝します)。

解決策は簡単でした。これを変える

  int * gains;

これに

  int gains[30];
于 2012-06-25T20:45:51.323 に答える