码迷,mamicode.com
首页 > 系统相关 > 详细

Linux C编程的DEBUG宏

时间:2015-08-13 22:15:57      阅读:284      评论:0      收藏:0      [点我收藏+]

标签:调试   linux   c语言   debug宏   

Linux C编程的DEBUG宏

在完成项目的过程中,免不了要进行调试,在这里我给大家介绍一种我正在使用的DEBUG宏。废话不多说,直接上代码。

实现代码

/*************************************************************************
    > File Name: debug.c
    > Author: AnSwEr
    > Mail: 1045837697@qq.com
    > Created Time: 2015年07月23日 星期四 18时19分48秒
 ************************************************************************/

#include<stdio.h>
#define DEBUG_PRINT do{}while(0)

#if defined(DEBUG_PRINT)
#define DEBUG(...)\
        do{\
            fprintf(stderr,"-----DEBUG-----\n");\
            fprintf(stderr,"%s %s\n",__TIME__,__DATE__);\
            fprintf(stderr,"%s:%d:%s():",__FILE__,__LINE__,__func__);\
            fprintf(stderr,__VA_ARGS__);\
        }while(0)
#endif

int main(void)
{
    DEBUG("Debug successfully!\n");
    return 0;
}

说明

1. do{}while(0):使用do{…}while(0)构造后的宏定义不会受到大括号、分号等的影响,而且可以定义空宏而不受警告。
2. 参数介绍:

 __LINE__:在源代码中插入当前源代码行号;
 __FILE__:在源文件中插入当前源文件名;
 __DATE__:在源文件中插入当前的编译日期
 __TIME__:在源文件中插入当前编译时间;
 __func__:输出函数名称,功能与_Function_相同;
 __VA_ARGS__:可变参数类型。

注意:具体代码可以参见https://github.com/AnSwErYWJ/DogFood/blob/master/debug.c

版权声明:本文为博主原创文章,未经博主允许不得转载。

Linux C编程的DEBUG宏

标签:调试   linux   c语言   debug宏   

原文地址:http://blog.csdn.net/u011192270/article/details/47622311

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!