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

  • 相关阅读:
    SpringBoot非官方教程 | 第九篇: springboot整合Redis
    SpringBoot非官方教程 | 第八篇:springboot整合mongodb
    SpringBoot非官方教程 | 第七篇:springboot开启声明式事务
    SpringBoot非官方教程 | 第六篇:springboot整合mybatis
    SpringBoot非官方教程 | 第五篇:springboot整合 beatlsql
    SpringBoot非官方教程 | 第四篇:SpringBoot 整合JPA
    SpringBoot非官方教程 | 第三篇:SpringBoot用JdbcTemplates访问Mysql
    SpringBoot非官方教程 | 第二篇:Spring Boot配置文件详解
    SpringBoot非官方教程 | 终章:文章汇总
    SpringBoot非官方教程 | 第一篇:构建第一个SpringBoot工程
  • 原文地址:https://www.cnblogs.com/lovelacelee/p/2823645.html
Copyright © 2011-2022 走看看