Android jni ndk crash c++bug定位

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

最近遇到了一个底层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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值