免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1683 | 回复: 0
打印 上一主题 下一主题

Sco Unix下用dbxtra调试C程序 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-01-21 18:18 |只看该作者 |倒序浏览
在sco unix下编程大多离不开C语言,即使是数据库应用也有很多是与c搭配使用的,例如informix esql/c 就可以在c语言中嵌入sql 语句。很多人认为在unix下写程序是件很痛苦的事情,其中一个很重要原因是不知道在unix下怎样调试程序。其实在sco unix源码调试器是dbxtra或dbXtra,linux下是gdb。它们类似turbo c的调试器,可以跟踪源码变量。在unix 下调试程序有如下传统方法:
  一、在要调试语句之前,输出要调试的变量,利用printf()函数。  
  二、写日志文件,把结果输出到文件中避免屏幕混乱,利用fprintf()函数。  
  三、利用sco 内置调试器dbxtra或dbXtra。  
  dbxtra 适用字符界面,在sco unix的图形界面用dbXtra。(编按:请注意大小写)  
  以下是dbxtra基本命令:
  c               cont      在断点后继续执行
  d               delete    删除所设断点
  h               help      帮助
  e               edit      编辑源程序
  n               next      源程序区的内容向下翻一屏。
  p               print     显示变量
  q               quit      退出dbxtra
  r               run       运行程序,直到遇上设置的断点
  rr              rerun     再次运行
  s               step      单步运行
  st              stop      设置断点
  j               status    显示当前断点  
  t        where  显示当前状态,列出所有设置的变量值
  di              display   开显示窗,用于查看变量
  ud              undisplay 删除显示窗的条目
  f               forward   源程序区的内容向上 翻一屏。
  B               backward  源程序区的内容向下 翻一屏。
  Stopi           stop inst 设置断点
  tracei          trace inst跟踪子程序  
  dbxtra [options] [objectfile ]
  dbxtra在启动时有个参数-Idir值得一提.我们在编写一个较大程序的时候,通常源程序和编译生成的可执行文件都放在不同的目录中,这样便于管理。默认dbxtra将在可执行文件所在的目录下找匹配c的源程序。当我们启动时,指定-I参数,dbxtra就会到我们指定的目录下找匹配的c程序。 例如:         
  dbxtra -I"\work\c" program1  
  源程序在用cc编译时要带上-g 参数,这样是加上符号表等调试信息。只有这样编译过的文件,dbxtra才可以调试。调试信息使源代码和机器码关联。  
  下面这个C程序输出结果和我们的预想结果不一样,说明某些地方有错误。我们用调试器来调试它:  
  程序一:  
t.c
main()
{  int   i=10 ,*p1;
   float j=1.5,*p2;
   p1=&
   p2=&
   p2=p1;
   printf("%d,%d\n",*p1,*p2);
}
  首先带上-g参数编译  cc -g -o t t.c
  启动调试器          dbxtra t
  屏幕显示:
1.main()
2.{  int   i=10 ,*p1;
3.   float j=1.5,*p2;
4.   p1=&
5.   p2=&
6.   p2=p1;
7.   printf("%d,%d\n",*p1,*p2);
8.}
C[browse] File:t.c    Func.-     
Readubg symbolic information
Type    'help' for help
(dbxtra)
(dbxtra)
  设置断点:
  (dbxtra)stop at 5
  运行:
  (dbxtra) run
  程序自动在第5行停下。
  这时我们可以看变量的值。
  (dbxtra) print *p1
  单步执行。
  (dbxtra)  step  
  程序将执行第5行源码,指针将移到第6行。
  (dbxtra)  print *p2
  (dbxtra) step
  程序执行了第6行源码后,将指针移到第7行。
  (dbxtra) print *p1 , *p2
  我们发现在执行了第6行源码后,*p1,*p2的值就不对了,所以问题就出在第6行上。仔细检查后发现指针p1指向整型,指针p2指向实型。它们之间的赋值要进行强制类型转换。这种错误在C程序中是很常见的。有时我们在调试一些程序时,要在整个程序运行中时刻监视莫些变量的值,例如程序一中我们要时刻了解*p1,*p2的值,除了在每一行程序执行完后,打print *p1,*p2外,还可以开一个显示窗口。  
  (dbxtra)display *p1,*p2  
  用undisplay 删掉不想要的变量。  
  有些程序运行时要带参数,mycat /etc/passwd 在调试时候  
  (dbxtra) run '/etc/passwd'  
  再运行时,无需再写一遍参数。  
  (dbxtra) rerun  
  在涉及到curses库编程或屏幕有大量的人机界面时,为了调试方便,我们可以把程序输出结果重定向到个虚屏。  
  (dbxtra) run >/dev/tty03  
  当然要先把tty03 disable 掉。(disable tty03)  
  dbxtra还有很多高级的用法,有兴趣的读者可以参照dbxtra本身的help,进一步研究。


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/13151/showart_69716.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP