gdb [options] --args executable-file [inferior-arguments ...]

  • l - 相当于list命令,l 37 显示37行附近的源码
  • b 行号,b 37 if i==3
  • b 函数名.函数名
  • i b - 查看全部断点信息
  • d - 删除所有断点
  • d 0 - 删除第0个断点
  • display a - 一直显示a的值
  • undisplay - 去掉所有显示
  • watch addr - 监控addr内存
  • s - step的意思进入函数进行跟踪
  • j 37 - 直接跳到37行运行
  • u - 将循环执行完
  • p a - 打印a的值
  • p a=3 - 设置a的值,p (*(mystruct *)addr) 打印一个数据结构,addr为其地址
  • r - 运行程序到断点
  • n - next的意思继续执行下一条语句
  • c - continue的意思,继续执行跳过当前断点, c 3 忽略3次断点
  • bt - 查看函数堆栈
  • where - 查看堆栈信息
  • up - 回溯一层堆栈
  • down - 到下一层堆栈
  • shell - 进入shell,如果再exit会回到gdb, shell echo $env
  • enable n - 开启第n个断点
  • disable n - 禁用第n个断点
  • finish - 执行本函数并返回
  • dir - 加目录

 

关闭GDB时,发现未退出应用程序:

a. 查找被占用的端口
netstat -tln
netstat -tln | grep 8060
netstat -tln 查看端口使用情况,而 netstat -tln | grep 8060 则是只查看端口8060的使用情况
b. 查看端口属于哪个程序?端口被哪个进程占用
lsof -i:8060

kill -9 进程id
kill -9 24739

 

目的:使用gdb附加到一个正在运行的进程上,然后做一些调试,并安全退出。

2. 查看进程id #ps ax 或者 #ps au

3. 启动gdb

4. 使用file命令来指定进程所联系的程序源代码和符号表,例如:

6. 打断点,如下:

8. ctrl + c再次中断,回到gdb命令行,然后输入:deatch。
当你调试结束之后,可以使用该命令断开进程与gdb的连接(结束gdb对进程的控制),在这个命令执行之后,你所调试的那个进程将继续运行。