轉載請註明出處:
http://blog.csdn.net/aa464971/article/details/80589053
local reference table overflow (max=512)
當使用了大量的局部引用而沒有及時釋放的話,就可能出現局部引用表溢出,所以變量用完以後回收一下就可以了,需要注意的是參數傳的是jobject
類型
(*env)->DeleteLocalRef(env, jobject);
input is not valid Modified UTF-8: illegal start byte 0xa9
當調用(*env)->NewStringUTF
時會出現,是因爲傳進去的char*
不是UTF-8,轉成UTF-8即可;
還有一種方法是轉成jbyteArray
,傳到Java後再轉成String。
C
void test(const char *text) {
int len = strlen(text);
if (len > 0) {
jbyteArray text_bytes = (*env)->NewByteArray(env, len);
//將C字符串轉成jbyteArray
(*env)->SetByteArrayRegion(env, text_bytes, 0, len, (jbyte *) text);
//回調給java
(*env)->CallVoidMethod(env, jobject, "javaTest", text_bytes);
(*env)->DeleteLocalRef(env, text_bytes);
}
}
Java
public void javaTest(byte[] textByteArray) {
String text = new String(textByteArray);
}