打印本文 打印本文 关闭窗口 关闭窗口
linux编程(2) GCC和GDB
作者:武汉SEO闵涛  文章来源:敏韬网  点击数1953  更新时间:2009/4/22 23:09:01  文章录入:mintao  责任编辑:mintao
bsp;
 
468                                                     break; 
469                             case CHILD_IO:          WaitingIo(); 
470                                                     break; 
显示了原代码,现在在AlarmMessage上加断点。 
(gdb) b AlarmMessage 
Breakpoint 2 at 0x8048ee3: file os.c, line 259. 
(gdb)
 
然后我们继续运行程序。 
(gdb)c 
c或continue命令让我们继续被中断的程序。 显示: 
Continuing. 
Use Control-C to halt 
 
Breakpoint 2, AlarmMessage () at os.c:259 
259             ClearSignal();
 
注意我们下一句语句就是ClearSignal(); 
我们用s/step跟踪进入这个函数看看它是干什么的。 
(gdb) s 
ClearSignal () at os.c:227 
227             signal(SIGINT,SIG_IGN);
 
用l命令列出原代码: 
(gdb) l 
222     } 
223 
224 
225     void ClearSignal()    /* Clear other signals */ 
226     { 
227             signal(SIGINT,SIG_IGN); 
228             signal(SIGALRM,SIG_IGN); 
229             signal(SIGUSR2,SIG_IGN); 
230     } 
231 
(gdb) 
我们可以用s命令继续跟踪。现在让我们来试试bt或backtrace命令。这个命令可以 
显示栈中的内容。 
(gdb) bt 
#0  ClearSignal () at os.c:227 
#1  0x8048ee8 in AlarmMessage () at os.c:259 
#2  0xbffffaec in ?? () 
#3  0x80486ae in ___crt_dummy__ () 
(gdb)
 
大家一定能看懂显示的意思。栈顶是AlarmMessage,接下来的函数没有名字--就是 
没有原代码符号。这显示了函数调用的嵌套。 
好了,我们跟踪了半天还没有检查过变量的值呢。检查表达式的值的命令是p或print 
格式是p <表达式> 
444444让我们来找一个变量来看看。:-) 
(gdb)l 1 
还记得l的作用吗?l或list显示原代码符号,l或list加<行号>就显示从<行号>开始的 
原代码。好了找到一个让我们来看看WaitingQueue的内容 
(gdb) p WaitingQueue 
$1 = {1, 2, 3, 4, 5, 6, 0} 
(gdb)
 
WaitingQueue是一个数组,gdb还支持结构的显示, 
(gdb) p Pcb 
$2 = {{Pid = 0, State = 0, Prior = 0, pc = 0}, {Pid = 31474, State = 2, 
    Prior = 24, pc = 0}, {Pid = 31475, State = 2, Prior = 19, pc = 0}, { 
    Pid = 31476, State = 2, Prior = 16, pc = 0}, {Pid = 31477, State = 2, 
    Prior = 23, pc = 0}, {Pid = 31478, State = 2, Prior = 22, pc = 0}, { 
    Pid = 31479, State = 2, Prior = 20, pc = 0}} 
(gdb)
 
这里可以对照原程序看看。 
原文档里是一个调试过程,不过我想这里我已经把gdb的常用功能介绍了一遍,基本上 
可以用来调试程序了。:-) 

注:本文的资料大部分引用自
       1:《GCC技术参考大全》 清华大学出版社
       2:发 信 人:System_Killer(大家一起来发呆)           信区名称:Linux[4590] 
            信件提要:GDB(一) 
            原发信站:中国科大BBS站(Fri, 27 Mar 1998 02:31:49) 

上一页  [1] [2] 

打印本文 打印本文 关闭窗口 关闭窗口