adb shell getprop指令查看当前设备的cpu架构arm-linux-androideabi编译工具 gdb和gdbserver皆存放在此开发包下第一步 编写测试代码 文件名为test.c
#include <stdio.h>
int main(){
char *a="he"
printf("hello pangshu");
return 0;
}第二步 将测试代码编译成可执行文件
arm-linux-androideabi-gcc.exe -g test.c -o main -static #输出可执行文件名为main第三步 将可执行文件传送到模拟器中
adb push main /data/local/tmp第四步 将gdbserver工具传送到模拟器中
adb push gdbserver /data/local/tmp第五步 进入模拟器shell窗口,使用gdbserver执行程序
./gdbserver 192.168.177.71:23946 main #这里的ip是宿主机的ip 23946为监听端口第六步 在宿主机中运行gdb工具
gdb.exe main #这里需要指定调试的执行文件此时进入到gdb模式
第七步 在gdb模式下连接模拟器中的gdbserver
(gdb) target remote 192.168.0.1:23946 #这里的ip是模拟器的ip连接成功后进入断点调试模式,该模式下可以使用~调试指令进行相关调试
使用list指令列出所有源代码 可简写为l
使用break指令设置断点位置 可简写为b
使用continue指令运行到断点处 可简写为c
使用step指令进行单步执行 可简写为s
使用next执行进行单步执行 可简写为n
使用print指令打印变量的值 可简写为a
使用quit指令退出调试模式 可简写为q
GCC调试工具GDB的常用指令
arm-linux-androideabi的获取建议下载Android NDK开发包,然后将里面的GCC套件单独抽出来使用,NDK提供了抽包脚本make-standalone-toolchain,在bulid目录的tools文件夹中可以找到,执行脚本自动抽取打包成压缩包到当前目录:
python make-standalone-toolchain.py --arch arm如果是在非安卓系统的ARM模拟器上,比如qemu模拟器,那么直接使用官方的arm-none-linux-eabi即可,即便是安卓设备,如果没有代码调试需求的话,仅仅是编译运行程序,也是完全够用了
但是你需要进行代码调试的话,由于android系统的安全策略,arm-none-linux-eabi包中的gdbserver无法运行,提示:
error: only position independent executables (PIE) are supported.为了解决这个问题,我们因此采用arm-linux-androideabi,这里面的gdbserver可以正常运行
上面的例子中使用的NDKr17的版本