android ndk中的工具使用
阿新 • • 發佈:2019-01-01
1. 動態so處理:
arm-linux-androideabi-readelf.exe -a XX.so > xx.txt
輸出所有函式
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處理:
arm-linux-androideabi-ar.exe -t xx.a > xx.txt
輸出.a內所有函式輸出.a內所有函式arm-linux-androideabi-nm.exe xx.a > xx.txt
3. ndk編譯
上面兩種庫檔案,.a和.so都可以直接通過 arm-linux-androideabi-g++.exe 工具編譯,編譯語法跟linux上的g++一致。 也可以直接使用ndk-build命令!4. crash定位
1)使用addr2line將地址轉化成程式碼行數,輸入的so為帶符號表的,即為strip過的:arm-linux-androideabi-addr2line.exe -f -e E:\dev_code\Sosomap-old\Sosomap-jni\obj\local\armeabi\libXX.so 000263ae
2)使用ndk-stack.exe還原堆疊:
-sym為帶符號表的so路徑, -dump為crash的堆疊資訊,必須包含:********** Crash dump: **********ndk-stack -sym E:\dev_code\Sosomap-old\Sosomap-jni\obj\local\armeabi -dump D:\android-ndk-r9b-windows-x86\txmap_log.txt