C语言调试手段:锁定错误

    在项目开发工程中,如果能确定哪个文件下的哪个函数下的哪行出错--即锁定错误,那该多好啊,该文章就是为此而作的。偷笑

 

首先来了解一下文件默认的输出信息的函数吧:

文件信息函数:

   printf("line : %d\n", __LINE__);                   //当前行数
  printf("filename : %s\n", __FILE__);             //当前文件名
  printf("function : %s\n", __FUNCTION__);  //当前函数
   printf("time : %s\n", __TIME__);                  //当前时间
   printf ("date : %s\n",  __DATE__);              //当前日期

输出:

line : 10
filename : test.c
function : main.c
time : 14:13:51
date : Oct 13 2012

 

理论已足,那就来看看如何锁定错误吧:

一、源文件:

[root@localhost for_test]# cat erroutput.c
#include <stdio.h>
#include <assert.h>

#define _DEBUG(msg...)    printf("[ %s,%s, %d ]=>",__FILE__, __FUNCTION__, __LINE__);  printf(msg);printf("\r\n")
#define _ERROR(msg...)    printf("[ error: %s, %d]=>", __FILE__,  __LINE__);printf(msg); printf("\r\n")
#define _ASSERT(exp)      \
                        do {\
                                if (!(exp)) {\
                                printf( "[ %s ]  ",#exp);printf("\r\n");\
                                assert(exp);\
                                }\
                        } while (0)

int main(void)
{
        char *p = NULL;
        _DEBUG("DEBUG!");
        _ERROR("ERROR!");
        _ASSERT(NULL != p);
        return 0;
}

二、输出:

[root@localhost for_test]# gcc erroutput.c
[root@localhost for_test]# ./a.out
[ erroutput.c,main, 17 ]=>DEBUG!
[ error: erroutput.c, 18]=>ERROR!
[ NULL != p ]
a.out: erroutput.c:19: main: Assertion `((void *)0) != p' failed.
已放弃


TI处理:

#ifdef DEBUG

    #define DBG(fmt, args...)  printf("Debug " fmt, ##args)// ##运算符用于把参数连接到一起。预处理程序把出现在##两侧的参数合并成一个符号

#else

    #define DBG(fmt, args...)

#endif

#define ERR(fmt, args...)  printf("Error " fmt, ##args)

[root@localhost for_test]# cat debug_err.c

#include <stdio.h>

//#define DEBUG

int main(void)

{

       DBG("xxxx\n");

       ERR("xxxx\n");

       return 0;

}

[root@localhost for_test]# ./a.out

Error xxxx

 

#ifdef __DEBUG

    #define DBG(fmt, args...) fprintf(stderr,"Encode Debug: " fmt, ## args)

#else

    #define DBG(fmt, args...)

#endif

#define ERR(fmt, args...) fprintf(stderr,"Encode Error: " fmt, ## args)



  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值