Mar*_*los 2 java-native-interface android android-ndk android-stlport
虽然Android-NDK(Android的JNI)我试图使用STL使其更容易使用字符串.
以下代码在执行时崩溃:
__android_log_print(ANDROID_LOG_DEBUG, "RMSDK:RMServices", "[%s]", "Converting");
std::string str("mark");
__android_log_print(ANDROID_LOG_DEBUG, "RMSDK:RMServices", "[%s]", str);
Run Code Online (Sandbox Code Playgroud)
执行时,将打印以下堆栈.
DEBUG/RMSDK:RMServices(11786): [Converting]
INFO/DEBUG(31): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
INFO/DEBUG(31): Build fingerprint: 'generic/sdk/generic/:2.2/FRF91/43546:eng/test-keys'
INFO/DEBUG(31): pid: 11786, tid: 11786 >>> br.com.iba <<<
INFO/DEBUG(31): signal 11 (SIGSEGV), fault addr deadbaad
INFO/DEBUG(31): r0 00000000 r1 00000000 r2 00000027 r3 00000000
INFO/DEBUG(31): r4 00000000 r5 deadbaad r6 00001728 r7 4618bd80
INFO/DEBUG(31): r8 00261938 r9 002a5df0 10 00000000 fp 00000000
INFO/DEBUG(31): ip ffffffff sp beb41880 lr afd154c5 pc afd11dc4 cpsr 40000030
INFO/DEBUG(31): #00 pc 00011dc4 /system/lib/libc.so
INFO/DEBUG(31): #01 lr afd154c5 /system/lib/libc.so
INFO/DEBUG(31): code around pc:
INFO/DEBUG(31): afd11da4 1c2bd00b 2d00682d e026d1fb 2b0068db
Run Code Online (Sandbox Code Playgroud)
我可以看到,"[Converting]"得到打印然后在std :: String初始化时崩溃.
PS:在我的Application.MK(在jni文件夹下)我有以下行:
APP_STL := gnustl_static
Run Code Online (Sandbox Code Playgroud)
你不能将std :: string传递给__android_log_print的"%s"格式化程序 - 它希望你传递它char *
.使用std :: string c_str()
将完成这项工作:
std::string str("mark");
__android_log_print(ANDROID_LOG_DEBUG, "RMSDK:RMServices", "[%s]", str.c_str());
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
2737 次 |
最近记录: |