有兩種方法可以分析 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-eabi-addr2line
例如:arm-eabi-addr2line -C -f -e libxxx.so 0x#####(輸出日志中最上面的pc值,可以回溯最終函數調用順序)