GDB 常用命令

调试前提:
-g 编译所有的代码
	包括汇编和.c

1. 打开gdb 并加载镜像

  • 第一种方式(远程调试)
1. 打开 gdb
gdb
2. 连接服务器
target remote localhost:1234
3. 加载并运行
file xxx.elf
load
run
  • 第二种方式(本地调试)
1. 打开 gdb
gdb ./app
2.让其开始运行
run

单个调试命令

  • 文件类
file
load
  • 控制类
run
c
n
s
halt
  • 地址类
3. 打印地址中的值
命令格式:x/nfu <addr>
(gdb)x/1xb 0x7fffffffd708
---------------------------
x : examine 的缩写
---------------------------
n : 表示要显示的内存单元个数
---------------------------
f : 表示显示方式, 可取如下值
x 按十六进制格式显示变量。
d 按十进制格式显示变量。
u 按十进制格式显示无符号整型。
o 按八进制格式显示变量。
t 按二进制格式显示变量。
a 按十六进制格式显示变量。
i 指令地址格式
c 按字符格式显示变量。
f 按浮点数格式显示变量。
---------------------------
u表示一个地址单元的长度,与n一起表示显示的地址长度
b表示单字节,
h表示双字节,
w表示四字节,
g表示八字节
修改地址值
print *(char*)0xbff444f1=5
print *(int*)0xbff444f1=0x55555555
  • 断点类
break
info break
  • 变量类
查看
p *tmp_p
p/x array
修改
set x = 12
set array 1 2 3 4
  • 寄存器类
p $sp
p $r1
info registers
info all-registers

x $sp
x/1 $sp
x/2 $sp
x/10 $sp

脚本

把 一个个命令写到 一个 txt 里 , 然后在 gdb 命令行下 source 该 txt
上一篇:IBM X3650 M3/M4的服务器装系统


下一篇:qtp中type方法的按键常量