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 回答