jni crash错误定位

jni经常崩溃打印出addr日志,

01-01 17:59:38.596: I/DEBUG(253): #03 pc 00000e80 /data/app-lib/com.example.hellojni-1/libhello-jni.so (__aeabi_idiv0+8)

01-01 17:59:38.596: I/DEBUG(253): #04 pc 00000cf4 /data/app-lib/com.example.hellojni-1/libhello-jni.so (willCrash+32)

对于Android 程序员来说比较抓瞎不知道如何解读。这种日志最多只能解读出哪个so出事了并不知道具体是哪一行出事。

解决:

使用arm-linux-androideabi-addr2line  定位出错位置

使用的 ndk路径/toolchains/arm-linux-androideabi-4.8/prebuilt/darwin-x86_64/bin/arm-linux-androideabi-addr2line -e 生成so库的项目路径/obj/local/armeabi-v7a/libhello-jni.so 00000cf4(错误地址)。

注意:解读时使用的so库并非是你在lib目录调用的so库,而是你在编译该so库时在obj目录下产生的对应的那个so库。

如果执行上面命令后打印出 hello-jni.c:10(具体的行号)则表示解读成功,可以去该行看看情况了。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值