我的这个错误是这样产生的。我的程序大量使用java的jni功能,并在某些时候会频繁的java和C相互调用,这样在程序运行一段时间后就出现了题目中所说到的内容ReferenceTable overflow (max=512)。
从字面上我对这个错误的理解是这样的:java的垃圾处理里面有个叫引用计数的东东,我这里看到的错误貌似就是在说这个问题,引用计数表溢出?
于是我找了自己的代码,不停的屏蔽,发现错误竟然出现在<c中回调java方法>时候的这样一句话里:
void BluetoothRelayer_relayToBluetoothAdapter(unsigned char* buffer, int num)
{
// 创建一个新的数据对象,作为java函数调用的参数
jbyteArray data = (*s_env)->NewByteArray(s_env, num);
(*s_env)->SetByteArrayRegion(s_env, data, 0, num, buffer);
// java 调用
(*s_env)->CallVoidMethod(s_env, s_objBluetoothRelayer,s_midRelayToBluetoothAdapter, data, num);
//LOGI("BluetoothRelayer_relayToBluetoothAdapter data %p", data);
//(*s_env)->ReleaseByteArrayElements(s_env, data, buffer, 0);
(*s_env)->DeleteLocalRef(s_env, data); //回调java中的方法,必须delete,release无法释放其引用资源
}
注意:jbyteArray data = (*s_env)->NewByteArray(s_env, num);释放资源data??
将 (*s_env)->ReleaseByteArrayElements(s_env, data, buffer, 0);
改为 (*s_env)->DeleteLocalRef(s_env, data); 释放资源OK