您的位置:首页 > 移动开发 > Android开发

arm-eabi-addr2line android应用崩溃的调试方法

2014-12-18 13:37 1301 查看
http://changxianli6121.blog.163.com/blog/static/56392130201312652555385/

1.将ndk中的arm-linux-androideabi-addr2line可执行文件的路径加入配置文件~/.bashrc中,例如:

export PATH=$PATH:~/dlna/android-ndk-r6b/toolchains/arm-linux-androideabi-4.4.3/prebuilt/linux-x86/bin

2.使配置生效:source ~/.bashrc

3.使用工具。例如:arm-linux-androideabi-addr2line -C -f -e ~/workspace/DLNA/libs/armeabi/libctrlpt.so 0003deb4

其中,0003deb4为堆栈信息中pc的值。


android应用崩溃的调试方法

有两种方法可以分析 crash 的堆栈信息

1 google提供了一个python脚本,可以从
http://code.google.com/p/android-ndk-stacktrace-analyzer/
下载这个python脚本,然后使用 adb logcat -d > logfile 导出 crash 的log,

使用 arm-eabi-objdump 位于build/prebuilt/linux-x86/arm-eabi-4.2.1/bin下面

把so或exe转换成汇编代码,如:arm-eabi-objdump -S mylib.so > mylib.asm,

使用脚本

python parse_stack.py <asm-file> <logcat-file>

2 直接使用NDK下面的arm-linux-androideabi-addr2line

(D:\android-ndk-r8\toolchains\arm-linux-

androideabi-4.4.3\prebuilt\windows\bin\arm-linux-androideabi-addr2line.exe)

例如:arm-linux-androideabi-addr2line -C -f -e libxxx.so 0x#####(address)

android调试工具addr2line使用补充

使用addr2line追踪自有动态库(so文件)的bug, 补充:

解决出现 ??:0 , 没法展示源代码行数的问题

在Android.mk 文件中:

Java代码

LOCAL_CFLAGS := -D__STDC_CONSTANT_MACROS -Wl,-Map=test.map -g

补充2个编译参数 -Wl,-Map=test.map -g .

增加gcc警告和调试标志

arm-linux-androideabi-addr2line -C -f -e /项目目录/obj/local/armeabi/libfaa_jni.so 0024362e

tip: 1,注意调试文件的位置在obj目录下,并非libs目录下生成的so文件

2,0024362e
为出错的机制位置

还有:

在jni/目录下增加Application.mk 文件, 修改为debug 模式,进行调试 APP_OPTIM := debug

具体application.mk 文件的配置见: http://blog.csdn.net/weidawei0609/article/details/6561280


其他参考:
http://blog.csdn.net/dysh1985/article/details/7558148 http://www.cnblogs.com/TerryBlog/archive/2012/02/23/2364862.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: