GDB调试

给出例子代码:
不考虑我的代码中的c/c++混用情况QAQ

#include<iostream>
#include<stdlib.h>
#include<string.h>
using namespace std;
int main()
{
   int a=10;
   char c = 'a';
   int* p = &a;
   int* w = (int *)malloc(sizeof(int) * 3);
   cout<<a<<endl<<c<<endl<<*p<<endl;
   memset(w, 1, 2*sizeof(int));
   free(w);
   return 0;
}

编译:gdbdemo.cpp 里面就是上方的代码,一定要加上 -g

g++ -g gdbdemo.cpp -o demo 

gdb调试:也可以不加 -q,gdb demo就会出现gdb的一些版本等信息

zy@july-ubuntu:~/LianXi/mon10/day22$ gdb -q demo
Reading symbols from demo...done.
(gdb) 

gdb显示代码列表:

Reading symbols from demo...done.
(gdb) l
1	#include<iostream>
2	#include<stdlib.h>
3	#include<string.h>
4	using namespace std;
5	
6	int main()
7	{
8	   int a=10;
9	   char c = 'a';
10	   int* p = &a;
(gdb)                            (这里是回车键,表示继续上一个操作 l )
11	   int* w = (int *)malloc(sizeof(int) * 3);
12	   cout<<a<<endl<<c<<endl<<*p<<endl;
13	   memset(w, 1, 2*sizeof(int));
14	   free(w);
15	   return 0;
16	}
(gdb) 

gdb开始调试命令:

(gdb) start
Temporary breakpoint 1 at 0x4009e1: file gdbdemo.cpp, line 7.
Starting program: /home/zy/LianXi/mon10/day22/demo 

Temporary breakpoint 1, main () at gdbdemo.cpp:7
7	{
(gdb) 

gdb设置断点breakpoints n, 并运行run

(gdb) b 10
Breakpoint 2 at 0x4009fb: file gdbdemo.cpp, line 10.
(gdb) r
The program being debugged has been started already.
Start it from the beginning? (y or n) y
Starting program: /home/zy/LianXi/mon10/day22/demo 

Breakpoint 2, main () at gdbdemo.cpp:10
10	   int* p = &a;
(gdb) 

可见,运行值断点处,即第10行出停下来,注意,此时第10行断点出还没有运行
打印发现&p和&a的地址不相同,(注意,打印print变量的地址要用地址符&)

10	   int* p = &a;
(gdb) p p
$1 = (int *) 0x0
(gdb) p &a
$2 = (int *) 0x7fffffffde34
(gdb) 

gdb 继续下一行的操作,这里n — next(逐行代码调试,但是遇到调用的函数不会跳转进入函数,如果想要进入行数,使用s——step),c——continue ,表示一直运行直到结束或者下一个断点停止

(gdb) n
11	   int* w = (int *)malloc(sizeof(int) * 3);
(gdb) p &a
$3 = (int *) 0x7fffffffde34
(gdb) p p
$4 = (int *) 0x7fffffffde34
(gdb) 

gdb 查看某地址中的存储的变量结果:

13	   memset(w, 1, 2*sizeof(int));   (为w申请了3×4=12个字节的空间,但是只初始化前面的2×4=8个字节)
(gdb) n
14	   free(w);
(gdb) x /12bd w
0x613c20:	1	1	1	1	1	1	1	1
0x613c28:	0	0	0	0
(gdb) x /13bd w 
0x613c20:	1	1	1	1	1	1	1	1
0x613c28:	0	0	0	0	0
(gdb) x /16bd w
0x613c20:	1	1	1	1	1	1	1	1
0x613c28:	0	0	0	0	0	0	0	0
(gdb) x /1wd w
0x613c20:	1684300900000001 00000001 00000001 00000001 = 16843009(gdb) x /4wd w
0x613c20:	16843009	16843009	0	0
(gdb) 

总结gdb x指令:

gdb)x /ndf &p(某个地址)
n: 表示个数,需要查看多少个数据
d:个数n的单位,表示查看以d个字节为单位的n个数据
f: 查看的数据以什么形式显示出来

d的选项有:

b —— 单字节
h —— 双字节
w —— 四字节
g —— 八字节

f 的选项有:

d —— 按照十进制格式显示
x —— 按照十六进制格式显示
a —— 按照十进制格式ox…这样的格式显示
u —— 按照十六进制格式显示无符号整形
o —— 按照八进制格式显示
t —— 按照二进制格式显示
c —— 按照字符格式显示
f —— 按照浮点数格式显示

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
FreeRTOS是一个开源的实时操作系统,它提供了一套用嵌入式系统的任务调度和管理机制。GDB(GNU Debugger)是一个功能强大的调试工具,可以用于调试C/C++程序。在使用FreeRTOS进行开发时,可以结合GDB进行调试。 要在FreeRTOS中使用GDB进行调试,需要进行以下几个步骤: 1. 配置编译器:首先,需要确保你的编译器支持GDB调试功能。常用的编译器如GCC和Keil都支持GDB调试。 2. 编译选项:在编译FreeRTOS应用程序时,需要添加一些编译选项以支持GDB调试。例如,在GCC中,可以使用"-g"选项来生成调试信息。 3. 连接器脚本:在链接应用程序时,需要使用连接器脚本来指定调试信息的位置。连接器脚本可以告诉GDB在哪里找到符号表和调试信息。 4. 启动GDB调试:在编译和链接完成后,可以使用GDB启动调试会话。可以通过命令行输入"gdb"命令来启动GDB,并使用"target remote"命令连接到目标设备。 5. 设置断点:在GDB中,可以使用"break"命令设置断点。可以设置函数断点、行号断点或地址断点等。 6. 执行调试:一旦设置好断点,可以使用GDB调试命令来执行程序。可以使用"run"命令来运行程序,使用"step"命令逐行执行,使用"next"命令执行下一行,使用"continue"命令继续执行等。 7. 查看变量:在调试过程中,可以使用GDB的"print"命令来查看变量的值。可以使用"info locals"命令查看局部变量,使用"info global"命令查看全局变量等。 8. 结束调试:当调试完成后,可以使用GDB的"quit"命令退出调试会话。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值