Android jni ndk crash c++bug定位

当遇到Android应用中JNI层或C++库的崩溃问题时,可以使用NDK提供的ndk-stack工具进行错误定位。通过运行`adb logcat | ndk-stack -sym [库路径]`,可以将堆栈信息转换为可读的源代码位置,便于调试。在文中,作者分享了如何解决重复启动线程导致的问题,以及在解析JSON过程中遇到的崩溃,这些问题通过代码审查和注释排查最终得到解决。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近遇到了一个底层c++库的问题 然而看不到是在哪里报错的。

有一个方法就是用 ndk-stack的方法

在cmd里面切换到adb 在电脑上的目录,

然后输入adb logcat | ndk-stack -sym F:/whl/MyApp(替换为你的项目目录)/build/intermediates/ndkBuild/afat/debug/obj/local/arm64-v8a

然后就会打印出堆栈信息:

 

然后还遇到了另一个问题:

JNI DETECTED ERROR IN APPLICATION: thread Thread[54,tid=5689,Native,Thread*=0x8a4de500,peer=0x12dc89d0,"JS Thread"] using JNIEnv* 

from thread Thread[54,tid=5689,Native,Thread*=0x8a4de500,peer=0x12dc89d0,"JS Thread"]'

然后是重复启动线程导致的,后面取消一个启动就好了。 

后面又遇到了一个这个问题:

 /data/app/com.hiha.im-1/lib/arm64/libtmessages.29.so (_Z21dispatcherCheckThreadPN10dispatcher12ImDispatcherESsi+940): Routine print_array at F:/whl/06im/dove-Android/TMessagesProj/jni/./gateway/imcjson.c:461
Stack frame 08-20 15:39:17.893 26262 26262 F DEBUG   :     #23 pc 00000000001a32f8  /data/app/com.hiha.im-1/lib/arm64/libtmessages.29.so (_ZNSt6thread5_ImplISt12_Bind_simpleIFPFvPN10dispatcher12ImDispatcherESsiES4_SstEEE6_M_runEv+80): Routine ParseJson(char*, ServerHostList*) at F:/whl/06im/dove-Android/TMessagesProj/jni/./gateway/dispatcher.cpp:170
Stack frame 08-20 15:39:17.893 26262 26262 F DEBUG   :     #24 pc 00000000005a967c  /data/app/com.hiha.im-1/lib/arm64/libtmessages.29.so: Routine std::basic_streambuf<wchar_t, std::char_traits<wchar_t> >::sgetc() at /usr/local/google/buildbot/src/android/ndk-r15-release/out/build/tmp/build-21705/build-gnustl/static-arm64-v8aj4.9/build/include/streambuf:344
开始的时候查看对应c++基本库源码猜测是锁的问题,后面通过代码注释排查问题找到了问题所在。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值