一、使用gdb查看内存
命令: x /nfu
x 是 examine 的缩写
n表示要显示的内存单元的个数
f表示显示方式:
x 按十六进制格式显示变量
d 按十进制格式显示变量
u 按十进制格式显示无符号整型
o 按八进制格式显示变量
t 按二进制格式显示变量
a 按十六进制格式显示变量
i 指令地址格式
c 按字符格式显示变量
f 按浮点数格式显示变量
u表示一个地址单元的长度
b 单字节
h 双字节
w 四字节
g 八字节
例子:
x /1dw address
从内存地址address读取内容,显示一个4字节的十进制整数
二、调试子进程
1.set follow-fork-mode
如在fork函数执行之前执行set follow-fork-mode child,默认gdb是调试主进程的。
2.attach
利用attach 命令附着到子进程然后进行调试。
三、利用gdb捕捉后台进程的输出
call close(1)
call open("...")
call dup2(...,1)
四、监视值变化
1、使用watch variable设置监视点,当value变化时,gdb会中断。
2、当离开variable的定义范围时,可能会使监视点不起作用。 可以使用地址监视:
print &variable找出地址address,然后watch *(int*)address。