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

  • 相关阅读:
    BZOJ 3150 [Ctsc2013]猴子 ——期望DP 高斯消元
    BZOJ 4569 [Scoi2016]萌萌哒 ——ST表 并查集
    BZOJ 4590 [Shoi2015]自动刷题机 ——二分答案
    BZOJ 3462 DZY Loves Math II ——动态规划 组合数
    BZOJ 4827 [Shoi2017]分手是祝愿 ——期望DP
    BZOJ 4827 [Hnoi2017]礼物 ——FFT
    BZOJ 4826 [Hnoi2017]影魔 ——扫描线 单调栈
    ZOJ 3874 Permutation Graph ——分治 NTT
    UVA 12633 Super Rooks on Chessboard ——FFT
    HDU 2065 "红色病毒"问题 ——快速幂 生成函数
  • 原文地址:https://www.cnblogs.com/lovelacelee/p/2823645.html
Copyright © 2011-2022 走看看