Android JNI常見異常解決

轉載請註明出處:
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);
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章