C语言自定义打印调试宏函数

C语言自定义打印调试宏函数

在C语言工程中经常会用到打印调试,但到正式的程序又需要将打印调试的程序语句删除掉,一来二去就比较麻烦。所以想到使用预定于宏和宏函数来定义一些打印函数,在不需要打印调试时,只需要修改相应的预定义宏的值即可。源代码如下。

#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
#include <unistd.h>
#include <time.h>

/*
 * ANSI C标准定义了以下几种可供C语言使用的预定义宏
 * __LINE__ 在源代码中插入当前源代码行号
 * __FILE__ 在源代码中插入当前源代码文件名
 * __DATE__ 在源代码中插入当前编译日期(注意和当前系统日期区别开来)
 * __TIME__ 在源代码中插入当前编译时间(注意和当前系统时间区别开来)
 */
 
// 打印调试信息预定义宏 
#define DA_DEBUG_DEFINE 1
#define DA_DEBUG(format, ...) {if(1 == DA_DEBUG_DEFINE) printf("[DA_DEBUG][%s-%s][%s:%d]"format"\n", __DATE__, __TIME__, __FILE__, __LINE__, ##__VA_ARGS__);}

// 打印错误信息预定义宏 
#define DA_ERROR_DEFINE 0
#define DA_ERROR(format, ...) {if(1 == DA_ERROR_DEFINE) printf("[DA_ERROR][%s-%s][%s:%d]"format"\n", __DATE__, __TIME__, __FILE__, __LINE__, ##__VA_ARGS__);}

// 打印普通信息预定义宏 
#define DA_INFO_DEFINE 1
#define DA_INFO(format, ...) {if(1 == DA_INFO_DEFINE) printf("[DA_INFO][%s-%s][%s:%d]"format"\n", __DATE__, __TIME__, __FILE__, __LINE__, ##__VA_ARGS__);}

int main()
{
    int i = 3;
    char *error = "dsds";

	// 调用DA_DEBUG宏函数,DA_DEBUG_DEFINE 为 1有输出
    DA_DEBUG("%d %d", i, i + 3);
    // 调用DA_ERROR宏函数,DA_ERROR_DEFINE 为 0无输出
    DA_ERROR("%s", error);
    // 调用DA_INFO宏函数,DA_INFO_DEFINE 为 1 有输出
    DA_INFO("information");

    return 0;
}

运行结果
在这里插入图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DA0221

各位看官您往里面瞧一瞧看一看

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值