`

关于android ndk出现ReferenceTable overflow (max=1024)的解决方法

阅读更多

最近遇到一个问题,晚上找了很久没有找到解决方法,最后自己琢磨解决了,特拿出来和大家分享,以免有人遇到同样的问题。

       我的这个错误是这样产生的。我的程序大量使用java的jni功能,并在某些时候会频繁的java和C相互调用,这样在程序运行一段时间后就出现了题目中所说到的内容ReferenceTable overflow (max=512)。

      从字面上我对这个错误的理解是这样的:java的垃圾处理里面有个叫引用计数的东东,我这里看到的错误貌似就是在说这个问题,引用计数表溢出?

      于是我找了自己的代码,不停的屏蔽,发现错误竟然出现在c中调用java时候的这样一句话里
     jc = (*ev)->GetObjectClass(m_obj);

     其中jc是javaclass的变量,难道是这句话有泄漏导致java的引用计数不停增加?又或者是这句话影响到了别的什么东西?

      于是开始google,结果发现人家调用GetObjectClass的时候都调用啥子释放的东东啊,难道那个jc需要释放?????

       自己找了n久发现在不用jc的时候调用m_env->DeleteLocalRef(jc); 问题便解决了,嘎嘎

*********************************************************************************************

以上是一个网友的解决方法。

下面是我的方法:

/**
 * 加载录音片段的数据(30毫秒的录音片段)
 */
JNIEXPORT jint Java_com_mir_ksong_jni_Jni_loadRecorderBuffer
  (JNIEnv *env, jobject thiz, jshortArray shortBuffer){
      jRecorderBuffer = (env)->GetShortArrayElements(shortBuffer, 0 );
      Eighth_Tone pitch;
      short pitch_in_Hz;
      int score;
     
      //加载录音数据
      IVocalPitch_Model_Get(modle,&pitch_in_Hz,&pitch,score);
     
      //释放空间
    (env)->ReleaseShortArrayElements( shortBuffer, jRecorderBuffer, 0);
    return pitch_in_Hz;
  }

说白了就是释放空间。

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics