C语言调试手段:锁定错误的实现方法

作者:kgmucom   在线用户:33
风之恋奇迹私服技术网是一家提供最新互联网编程技术网站

在编程过程中,有时我们编写的程序在发生逻辑错误时不能运行正确的结果,这就要求我们调试一些容易出错的语句,下文是爱站技术频道小编为大家介绍的调试手段:锁定错误的实现方法,一起来看看吧!
首先来了解一下文件默认的输出信息的函数吧:
文件信息函数:

 

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)

以上就是C语言调试手段:锁定错误的实现方法,相信这些内容对大家都很有用,建议你可以好好收藏我们的专业的网站js.aizhan.com。

提供最全面的奇迹sf开服版本和最新的奇迹私服开服技术信息,奇迹私服文库让每一位奇迹私服玩家找到自己需要的版本技术文章

上一篇:VC WinExec打开指定程序或者文件的方法

下一篇:详解C语言中条件编译

请发表您的评论