ubuntu系统使用 GDB 调试多文件的详细操作步骤
来源:互联网 发布:阿里云1m带宽慢不慢 编辑:程序博客网 时间:2024/06/10 20:20
整理以前的笔记,仅作复习笔记备查,并实际操作了一遍OK。
All.c文件内容如下:
#include <stdio.h>
int main(void)
{
int a=8;
int b=3;
printf("a= %d b=%d \n",a,b);
int sum =add(a,b);
printf("a+b= %d \n",sum);
int cha=minus(a,b);
printf("a-b=%d\n",cha);
return 0;
}
Add.c文件内容如下:
int add(int a,int b)
{
int result;
result=a+b;
return result;
}
Minus.c文件内容如下:
int minus(int a,int b)
{
int result;
result=a-b;
return result;
}
三个文件放于同一个目录内。
目录文件如下:
root@ubuntu:/home/lin/mulfiles# ls
add.c add.o all all.c all.o makefile minus.c minus.o
Make操作后,GDB调试时无反应
查看 makefile文件:
root@ubuntu:/home/lin/mulfiles# cat makefile
all:all.o add.o minus.o
gcc all.o add.o minus.o -o all
all.o:all.c
gcc -c all.c -o all.o
add.o:add.c
gcc -c add.c -o add.o
minus.o:minus.c
gcc -c minus.c -o minus.o
clean:
rm -rf *.o all
原因是:编译选项忘记加 “-g”,在所有“-o”前加上即可。
root@ubuntu:/home/lin/mulfiles# vim makefile
root@ubuntu:/home/lin/mulfiles# ls
add.c add.o all all.c all.o makefile minus.c minus.o
root@ubuntu:/home/lin/mulfiles# make clean
rm -rf *.o all
root@ubuntu:/home/lin/mulfiles# ls
add.c all.c makefile minus.c
再次编译:
root@ubuntu:/home/lin/mulfiles# make
gcc -c all.c -g -o all.o
gcc -c add.c -g -o add.o
gcc -c minus.c -g -o minus.o
gcc all.o add.o minus.o -g -o all
root@ubuntu:/home/lin/mulfiles# ls
add.c add.o all all.c all.o makefile minus.c minus.o
编译生成的文件名:“all”
开始调试:
root@ubuntu:/home/lin/mulfiles# gdb all
GNU gdb (Ubuntu/Linaro 7.4-2012.02-0ubuntu2) 7.4-2012.02
Copyright (C) 2012 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law. Type "show copying"
and "show warranty" for details.
This GDB was configured as "i686-linux-gnu".
For bug reporting instructions, please see:
<http://bugs.launchpad.net/gdb-linaro/>...
Reading symbols from /home/lin/mulfiles/all...done.
查看代码: ”l“ 命令,该命令每次列10行。
(gdb) l
1 #include <stdio.h>
2
3 int main(void)
4 {
5 int a=8;
6 int b=3;
7 printf("a= %d b=%d \n",a,b);
8 int sum =add(a,b);
9 printf("a+b= %d \n",sum);
10 int cha=minus(a,b);
设置断点:
add 函数在add.c文件中定义,在all.c文件中被调用,如上所示,在第8行,故断点设置如下:
(gdb) b 8
Breakpoint 1 at 0x804841a: file all.c, line 8.
(gdb) r
Starting program: /home/lin/mulfiles/all
a= 8 b=3
Breakpoint 1, main () at all.c:8
8 int sum =add(a,b);
运行后,在断点处停下,此时单步进入即可,如下所示:
(gdb) s
add (a=8, b=3) at add.c:4
4 result=a+b;
单步执行:
(gdb) n
5 return result;
查看变量值:
(gdb) p result
$1 = 11
继续单步:
(gdb) n
6 }
(gdb) 注意:此处并未输入”n“,回车时,默认执行上次一次操作。此处继续”n“动作。
main () at all.c:9
9 printf("a+b= %d \n",sum);
(gdb)
a+b= 11
单步执行到该语句时(此时未执行),单步进入操作:”s“。
10 int cha=minus(a,b);
(gdb) s
minus (a=8, b=3) at minus.c:4
4 result=a-b;
(gdb)
5 return result;
查看代码命令:”l”
Minus函数在all.c文件中调用,但是定义在minus.c文件里,”l“操作后,显示代码如下:
(gdb) l
1 int minus(int a,int b)
2 {
3 int result;
4 result=a-b;
5 return result;
6 }
查看相关变量值:
(gdb) p a
$2 = 8
(gdb) p b
$3 = 3
(gdb) p result
$4 = 5
(gdb) n
6 }
(gdb)
main () at all.c:11
11 printf("a-b=%d\n",cha);
(gdb) l
6 int b=3;
7 printf("a= %d b=%d \n",a,b);
8 int sum =add(a,b);
9 printf("a+b= %d \n",sum);
10 int cha=minus(a,b);
11 printf("a-b=%d\n",cha);
12 return 0;
13
14
15 }
(gdb) p cha
$5 = 5
(gdb) n
a-b=5
12 return 0;
(gdb)
15 }
(gdb)
0xb7e3d4d3 in __libc_start_main () from /lib/i386-linux-gnu/libc.so.6
- ubuntu系统使用 GDB 调试多文件的详细操作步骤
- 使用gdb调试的一般步骤
- ubuntu gdb 多线程调试步骤
- Ubuntu中gdb调试步骤
- Linux:GDB调试NS2项目详细步骤
- 详细的gdb调试流程
- linux系统下gdb调试详细解析
- 多文件gdb调试
- gdb的调试使用
- 使用GDB调试Coredump文件
- 使用GDB调试Coredump文件
- 使用 GDB 调试 CoreDump 文件
- 使用GDB调试Coredump文件
- GDB调试多文件的工程
- GDB调试多文件的工程
- 【转】使用GDB调试程序详细说明
- Linux下交叉编译gdb,gdbserver+gdb的使用以及通过gdb调试core文件
- android ndk-gdb 调试的步骤
- [LeetCode] Palindrome Partitioning 回文分割
- (软工视频总结)之软件维护和用户界面设计
- 武汉银行承兑汇票背书
- 【iOS开发】网络协议之HTTP协议
- this指针
- ubuntu系统使用 GDB 调试多文件的详细操作步骤
- 武汉什么样的企业工商年检需要审计报告
- 12_3
- Exception while invoking! org.apache.thrift.protocol.TProtocolException: Bad version in readMessageB
- 漏斗模型的头脑风暴
- 深入浅出DDoS攻击防御--攻击篇
- POJ3259 Wormholes 【SPFA判断负环】
- android5.0 renderthread对应用层影响的分析
- 判断点是否在多边形内(包括在多边形上)的一个算法