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

  • 相关阅读:
    一些Asp.Net面试题答案
    未能加载文件或程序集"Microsoft.Web.Infrastructure 的解决方案
    偶然的发现(与Code无关)
    配置一台测试机 每个域用户独立会话
    使用 Git 和 Visual Studio Online 进行版本控制
    1.大数据概述
    递归下降语法分析程序设计
    文法 LL1
    C语言的文法分析
    词法分析
  • 原文地址:https://www.cnblogs.com/lovelacelee/p/2823645.html
Copyright © 2011-2022 走看看