📄 00000002.htm
字号:
<HTML><HEAD> <TITLE>BBS水木清华站∶精华区</TITLE></HEAD><BODY><CENTER><H1>BBS水木清华站∶精华区</H1></CENTER>发信人: TJB (老六), 信区: Linux <BR>标 题: GDB (2) <BR>发信站: BBS 水木调试站 (Tue Jun 2 15:58:26 1998) <BR> <BR>发 信 人:System_Killer(大家一起来发呆) 信区名称:Linux[4614] <BR>信件提要:gdb(二) <BR>原发信站:中国科大BBS站(Sat, 28 Mar 1998 22:28:43) <BR> <BR>这里是GDB的一个例子: <BR> 原文中是使用一个叫m4的程序。但很遗憾我找不到这个程序的原代码, <BR>所以没有办法来按照原文来说明。不过反正是个例子,我就拿一个操作系统的 <BR>进程调度原码来说明把,原代码我会附在后面。 <BR> 首先这个程序叫os.c是一个模拟进程调度的原程序(也许是个老古董了:-))。 <BR>先说明一下如何取得包括原代码符号的可执行代码。大家有心的话可以去看一下gcc的 <BR>man文件(在shell下打man gcc)。gcc -g <原文件.c> -o <要生成的文件名> <BR>-g 的意思是生成带原代码调试符号的可执行文件。 <BR>-o 的意思是指定可执行文件名。 <BR>(gcc 的命令行参数有一大堆,有兴趣可以自己去看看。) <BR>反正在linux下把os.c用以上方法编译连接以后就产生了可供gdb使用的可执行文件。 <BR>我用gcc -g os.c -o os,产生的可执行文档叫os. <BR>然后打gdb os,就可进入gdb,屏幕提示: <BR> GDB is free software and you are welcome to distribute copies <BR> of it under certain conditions; type "show copying" to see <BR> the conditions. <BR> There is absolutely no warranty for GDB; type "show warranty" <BR> for details. <BR> <BR> GDB 4.16, Copyright 1995 Free Software Foundation, Inc... <BR> (gdb) <BR> (gdb)是提示符,在这提示符下可以输入命令,直到退出。(退出命令是q/Q) <BR>为了尽量和原文档说明的命令相符,即使在本例子中没用的命令我也将演示。 <BR>首先我们可以设置gdb的屏幕大小。键入: <BR> (gdb)set width 70 <BR>就是把标准屏幕设为70列。 <BR> 然后让我们来设置断点。设置方法很简单:break或简单打b后面加行号或函数名 <BR>比如我们可以在main 函数上设断点: <BR> (gdb)break main <BR>或(gdb)b main <BR> 系统提示:Breakpoint 1 at 0x8049552: file os.c, line 455. <BR> 然后我们可以运行这个程序,当程序运行到main函数时程序就会停止返回到gdb的 <BR>提示符下。运行的命令是run或r(gdb中有不少alias,可以看一下help,在gdb下打help) <BR>run 后面可以跟参数,就是为程序指定命令行参数。 <BR>比如r abcd,则程序就会abcd以作为参数。(这里要说明的是可以用set args来指定参 <BR>数)。打入r或run后,程序就开始运行直到进入main的入口停止,显示: <BR>Starting program: <路径>/os <BR> <BR>Breakpoint 1, main () at os.c:455 <BR>455 Initial(); <BR>这里455 Initial();是将要执行的命令或函数。 <BR>gdb提供两种方式:1.单步进入,step into就是跟踪到函数内啦。命令是step或s <BR> 2.单步,next,就是简单的单步,不会进入函数。命令是next或n <BR>这两个命令还有别的用法以后再说。 <BR>我们用n命令,键入: <BR>(gdb)n <BR>Success forking process# 1 ,pid is 31474 <BR> <BR>Success forking process# 2 ,pid is 31475 <BR> <BR>Success forking process# 3 ,pid is 31476 <BR> <BR>Success forking process# 4 ,pid is 31477 <BR> <BR>Success forking process# 5 ,pid is 31478 <BR> <BR>Success forking process# 6 ,pid is 31479 <BR> <BR> Dispatching Algorithm : FIFO <BR>******************************************************************************** <BR> <BR> PCB# PID Priority PC State <BR> 1 31474 24 0 WAITING <BR> 2 31475 19 0 WAITING <BR> 3 31476 16 0 WAITING <BR> 4 31477 23 0 WAITING <BR> 5 31478 22 0 WAITING <BR> 6 31479 20 0 WAITING <BR> <BR>****************************************************************************** <BR> <BR>CPU : NO process running <BR>IO : No process <BR>Waiting CPU!!! 31474 31475 31476 31477 31478 31479 <BR>Waiting IO NONE <BR>456 State=WAITING; <BR>最后的一行就是下一句要执行的命令。我们现在在另一个函数上加断点。注意我们 <BR>可以用l/list命令来显示原代码。这里我们键入 <BR>(gdb)l <BR>451 main() <BR>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -