下载gdb
gdb需要使用yum下载
yum -y install gdb
编译注意
需要在后面加上 -g ,证明是要给可调试文件。
开始调试
gdb+函数名
修改主函数参数
set args
//set args "小红" "小华" "爱你"
在linux中显示行号
在vi下,输入命令set number,若想不显示行号,则输入set nonumber
或者在vi下,快捷键ctrl+g,显示当前行号。
设置断点
break
简写是b
类似于VS的F9
//b 17 表示在11行设置断点
运行
run
简写是r
//r表示开始运行
第一行是启动程序,和参数
第二行就表示运行到17行了,等待下一步指示
下一步(不进入内部)
next
简写n
类似于VS的F10
下一步(进入函数内部)
step
简写s
类似于VS的F11
继续下一个断点
continue
简写c
类似于VS的F5
显示此时的参数
简写p
当然只能在有参数的一行使用,不然看不到。比如下面就到了for循环,已经脱离了参数,这时就看不见了 。就只能看到ii
改变参数(比如for循环的i值)
set var
无简写
&&
p 表达式赋值
先用p 演示,但一定要先进入for循环
先p ii =6,将循环的ii 提前,然后c运行,发现直接从7开始运行了。
再用set var,也要先进入循环。
退出
q
调试core文件
调试core文件的步骤如下:
1)用ulimit -a查看当前用户的资源限制参数;
2)用ulimit -c unlimited把core file size改为unlimited;
3)运行程序,产生core文件;
4)运行gdb 程序名 core文件名;
5)在gdb中,用bt查看函数调用栈。
然后,如果在程序运行的过程中如果发生了崩溃,就会自动生成core文件,可以调试core文件查看奔溃原因。
调试代码,下列代码错误原因是解引用了空指针
#include <cstring>
#include <iostream>
using namespace std;
void bb(const int bh,const string xm)
{
char *ptr=0;//错误原因在这里,解引用了空指针
*ptr=3;
//strcpy(ptr,xm.c_str());
}
void aa(const int no,const string name)
{
bb(3,"冰冰");
}
int main()
{
aa(8,"西施");
return 0;
}
编译后产生了core文件
开始调试core文件
gdb demo core.15248
gdb 可执行文件名 core文件名
然后发现程序在执行到第8行时关闭了
第二道保险—函数调用栈
有时候调试core文件并不会显示具体是哪一行错了
比如将空指针作用于strcop函数
报错后,并不能找到具体是哪里错了,没有具体说明是哪一行有错。
这个时候可以使用函数调用栈,bt命令
bt
然后发现是strcpy函数处有问题。
调试正在运行的程序
如果函数要打印1万次数据,每秒打印1次,这个时候就可以调制进行中的程序。
调试代码
#include <unistd.h>
#include <iostream>
using namespace std;
void bb(const int bh,const string xm)
{
for (int ii=0;ii<1000000;ii++)
{
sleep(1);
cout << "ii=" << ii << endl;
}
}
void aa(const int no,const string name)
{
bb(3,"冰冰");
}
int main()
{
aa(8,"西施");
return 0;
}
开始调试
输入命令,程序名就是可执行文件名,进程编号通过ps -ef |grep 可执行文件名查询
gdb 程序名 -p 进程编号
一旦开始调试,那么正在运行的程序就会停止,如果停止调试,那么就会继续运行程序。
输入bt,发现程序是在sleep函数里面停止。