Android JNI调用方法GetStringUTFLength崩溃

时间:2018-11-29 12:42:45

标签: java android android-ndk java-native-interface jnienv

代码

std::string abc(const char* param)
{
    JNIEnv *pJNIEnv = GetJNIEnv();

    //TODO : for testing
    jstring jstr = pJNIEnv->NewStringUTF("Ñandú");  //can pass param also
    std::string result = convertJStringToString(pJNIEnv, jstr);


    return result;
}


std::string convertJStringToString(JNIEnv *env, jstring str) {
    const jsize len = env->GetStringUTFLength(str);
    const char *strChars = env->GetStringUTFChars(str, (jboolean *) 0);
    std::string Result(strChars, len);
    env->ReleaseStringUTFChars(str, strChars);
    return Result;
}

在Play商店中获取崩溃报告

pid: 0, tid: 0 >>> x.abc.xyz <<<

backtrace:
  #00  pc 0000000000071914  /system/lib64/libc.so (tgkill+8)
  #01  pc 000000000001e058  /system/lib64/libc.so (abort+88)
  #02  pc 0000000000456740  /system/lib64/libart.so (_ZN3art7Runtime5AbortEPKc+528)
  #03  pc 0000000000456eb8  /system/lib64/libart.so (_ZN3art7Runtime7AborterEPKc+24)
  #04  pc 000000000054a840  /system/lib64/libart.so (_ZN7android4base10LogMessageD1Ev+912)
  #05  pc 00000000002e6534  /system/lib64/libart.so (_ZN3art9JavaVMExt8JniAbortEPKcS2_+1732)
  #06  pc 00000000002e683c  /system/lib64/libart.so (_ZN3art9JavaVMExt9JniAbortFEPKcS2_z+204)
  #07  pc 0000000000363b30  /system/lib64/libart.so (_ZN3art3JNI18GetStringUTFLengthEP7_JNIEnvP8_jstring+816)
  #08  pc 00000000001e205c  /data/app/x.abc.xyz-Sor8tcKXEtf7w-3TH6bZFw==/lib/arm64/libnative-lib.so (_Z22convertJStringToStringP7_JNIEnvP8_jstring+44)

无法理解为什么会崩溃,多数情况下是在Android 8.0上崩溃。请不要说传递jstring值NULL是在将jstring传递给此方法之前已经检查代码的原因。

1 个答案:

答案 0 :(得分:0)

我在Xiami电话上也遇到了类似的问题。这是格式化字符串的问题,在本机stacktrace之前,我遇到以下错误:

2020-07-28 10:35:51.321 6978-6978/cookbook.chapter2 A/okbook.chapter: art_method.cc:530] Check failed: found_virtual Didn't find oat method index for virtual method: int android.icu.text.DecimalFormat_ICU58_Android.getMinimumIntegerDigits()

问题代码正在格式化字符串(恰好是字符串格式化的最后一个参数):

__android_log_print(ANDROID_LOG_INFO, "native", "UTF-8 string with Chinese characters: %s, string length (number of bytes) %d=%d", newStr, newStrLen, strlen(newStr));