代码
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传递给此方法之前已经检查代码的原因。
答案 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));