zoukankan      html  css  js  c++  java
  • 自定义类printf变参数的输出函数_常用于调试

    自定义类printf变参数的输出函数,常用于调试

    在C99下可以使用如下方法:

    #ifdef DEBUG
    #include <stdio.h> 
    #define debug(fmt, x...) \
    do \
    { \
        printf("%s %s(Line %d): "fmt,__FILE__,__FUNCTION__,__LINE__, ##x); \
    }while(0)
    #else
    #define debug(fmt, x...)
    #endif
    
    

    或者

    #ifdef DEBUG
    #include <stdio.h> 
    #define debug(...) \
    do \
    { \
        printf("%s %s(Line %d): ",__FILE__,__FUNCTION__,__LINE__); \
        printf(__VA_ARGS__); \
    }while(0)
    #else
    #define debug(x...)
    #endif

    对于不支持变参数符号(…)的平台可以用

    #ifdef DEBUG
    #include <stdio.h> 
    #define debug(x) \
    do \
    { \
         printf("%s %s(Line %d): ",__FILE__,__FUNCTION__,__LINE__); \
         printf x;\
         printf("\n"); \
     }while(0)
     #else
     #define debug(x)
     #endif
    

    但在使用时就注意用双括号,如

    debug(("This is for debug\n"));
     

    非宏定义而用函数定义的方法:

    #define __DEBUG__
    
    #ifdef __DEBUG__
    #include <stdarg.h>
    void debug(const char *fmt, ...)
    {
        va_list ap;
        va_start(ap, fmt);
        vprintf(fmt, ap);
        va_end(ap);
    }
    #else
    void debug(const char *fmt, ...)
    {
    }
    #endif
     

    这样定义的函数与printf的用法一致。

    参考地址:http://linux.chinaunix.net

  • 相关阅读:
    p2394 精度题
    线性筛素数
    poj3468 线段树的懒惰标记
    逆元
    2018 Multi-University Training Contest 2
    2018 Multi-University Training Contest 1
    判断素数遇到的问题
    Mergeable Stack(链表实现栈)
    组合数
    poj2594 机器人寻找宝藏(最小路径覆盖)
  • 原文地址:https://www.cnblogs.com/lovelacelee/p/2823645.html
Copyright © 2011-2022 走看看