可变参数宏
#include <stdio.h>
#define __DEBUG__
#ifdef __DEBUG__
#define DEBUG(format, ...) printf("文件:"__FILE__ "\n行号:%d\n输出:"format"\n", __LINE__, ##__VA_ARGS__)
#else
#define DEBUG(format, ...)
#endif
int main(int argc, char **argv) {
char str[] = "Hello World";
float a = 889.5;
DEBUG("A ha, check me: %s %.2f", str, a);
return 0;
}
运行测试输出结果:
行号:18
输出:A ha, check me: Hello World 889.50
原始的测试行:
#define DEBUG(format,...) printf("File: "__FILE__"\nLine: %05d \n"format"\n", __LINE__, ##__VA_ARGS__)
%05d
输出占 5 格,前面不足的,补零. 如果%5d
,占 5 格,不足的空格.
format
参数名, 前后相同就行了,__VA_ARGS__
是可变参数宏, 宏参数对应前面的三个点(省略号), ##
的意思是,如果可变参数(format
, 就是后面的%s
)被忽略或为空,将使预处理器(preprocessor
)去除掉它前面的那个逗号
__LINE__
:在源代码中插入当前源代码行号;
__FILE__
:在源文件中插入当前源文件名;
另外: ...
只能放最后.
经测试, format
只能放第一个逗号前, 且挨着逗号,...
和对应的_VA_ARGS_
只能放在最后
参考:
http://blog.csdn.net/hinyunsin/article/details/6546670
http://blog.csdn.net/jinzhilong580231/article/details/8774259 // 删除逗号
http://blog.csdn.net/hinyunsin/article/details/6546670
http://blog.chinaunix.net/uid-22878837-id-2110544.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了