http://www.2cto.com/kf/201405/302672.html
1. 动态so处理:
1
|
arm-linux-androideabi-readelf.exe -a XX.so > xx.txt
|
输出所有函数
1
|
arm-linux-androideabi-objdump.exe -dx XX.so > xx.txt
|
反汇编so包,此时使用 $(JNI_PROJ_PATH)/obj\local\armeabi下面带符号表的so包。JNI_PROJ_PATH为编译so包时jni文件夹的根目录
2. 静态a处理:
1
|
arm-linux-androideabi-ar.exe -t xx.a > xx.txt
|
输出.a内所有函数
1
|
arm-linux-androideabi-nm.exe xx.a > xx.txt
|
输出.a内所有函数
3. ndk编译
上面两种库文件,.a和.so都可以直接通过 arm-linux-androideabi-g++.exe 工具编译,编译语法跟linux上的g++一致。 也可以直接使用ndk-build命令!
4. crash定位
1)使用addr2line将地址转化成代码行数,输入的so为带符号表的,即为strip过的:
1
|
arm-linux-androideabi-addr2line.exe -f -e E:\dev_code\Sosomap-old\Sosomap-jni\obj\local\armeabi\libXX.so 000263ae
|
2)使用ndk-stack.exe还原堆栈:
1
|
ndk-stack -sym E:\dev_code\Sosomap-old\Sosomap-jni\obj\local\armeabi -dump D:\android-ndk-r9b-windows-x86\txmap_log.txt
|
-sym为带符号表的so路径, -dump为crash的堆栈信息,必须包含:********** Crash dump: **********