一、使用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 <parent/child>
如在fork函数执行之前执行set follow-fork-mode child,默认gdb是调试主进程的。 2.attach<pid> 利用attach <pid>命令附着到子进程然后进行调试。三、利用gdb捕捉后台进程的输出
call close(1)
call open("...") call dup2(...,1)四、监视值变化
1、使用watch variable设置监视点,当value变化时,gdb会中断。
2、当离开variable的定义范围时,可能会使监视点不起作用。 可以使用地址监视:
print &variable找出地址address,然后watch *(int*)address。