关于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;
}

说白了就是释放空间。

你可能感兴趣的:(android NDK)