C / C++ 可变参数的宏,__VA_ARGS__,...

C++ Builder 参考手册 ➙ C / C++ 可变参数的宏,__VA_ARGS__,...


  • 宏的可变参数的写法
  • 例子

一. 宏的可变参数的写法

1. 单独的 ... 和 __VA_ARGS__

标准 C / C++ 语言宏定义的参数允许用三个小数点 ... 表示这里是可变参数,在宏替换的时候,用 __VA_ARGS__ 表示 ... 位置的所有的参数。
例如:
#define test1(...) printf(__VA_ARGS__)
#define test2(fmt, ...) printf(fmt, __VA_ARGS__)

2. 参数后面带三个小数点

很多编译器扩展了可变参数的宏替换,这样的写法更容易记忆,宏定义的参数后面可以带三个小数点,表示这里是可变参数,宏替换的时候,直接写这个参数就表示这个位置是所有的可变参数了。
例如:
#define test3(fmt...) printf(fmt)
#define test4(fmt, args...) printf(fmt, args)
注:某些编译器需要用 ##args 表示 args... 位置所有的参数的宏替换。

二. 例子

1. 测试本文前面提到的 test1 到 test4 替换 printf

#include 

#define test1(...) printf(__VA_ARGS__)
#define test2(fmt, ...) printf(fmt, __VA_ARGS__)
#define test3(fmt...) printf(fmt)
#define test4(fmt, args...) printf(fmt, args)

int main(void)
{
    int i = 10;
    float f = 3.1415926;
    const char *s = "Hello, Hsuanlu!";

    test1("test1: i = %d, f = %g, s = %s\n", i, f, s);
    test2("test2: i = %d, f = %g, s = %s\n", i, f, s);
    test3("test3: i = %d, f = %g, s = %s\n", i, f, s);
    test4("test4: i = %d, f = %g, s = %s\n", i, f, s);

    return 0;
}

运行结果:

test1: i = 10, f = 3.14159, s = Hello, Hsuanlu!
test2: i = 10, f = 3.14159, s = Hello, Hsuanlu!
test3: i = 10, f = 3.14159, s = Hello, Hsuanlu!
test4: i = 10, f = 3.14159, s = Hello, Hsuanlu!

说明 test1、test2、test3 和 test4 都能达到同样的效果。

2. 定义 TRACE 宏,格式化输出到调试程序的 Event Log 里面

这个例子仍然是测试宏的可变参数的几种写法,分别定义了 4 个宏:TRACE1、TRACE2、TRACE3 和 TRACE4。

#define TRACE1(...)          ::OutputDebugString(String().sprintf(__VA_ARGS__).c_str())
#define TRACE2(fmt, ...)     ::OutputDebugString(String().sprintf(fmt, __VA_ARGS__).c_str())
#define TRACE3(fmt...)       ::OutputDebugString(String().sprintf(fmt).c_str())
#define TRACE4(fmt, args...) ::OutputDebugString(String().sprintf(fmt, args).c_str())

void __fastcall TForm1::Button1Click(TObject *Sender)
{
    int i = 3;
    double f = 45.678;
    const wchar_t *s = L"Hello, Hsuanlu!";
    TRACE1(L"TRACE1: i = %d, f = %g, s = %s", i, f, s);
    TRACE2(L"TRACE2: i = %d, f = %g, s = %s", i, f, s);
    TRACE3(L"TRACE3: i = %d, f = %g, s = %s", i, f, s);
    TRACE4(L"TRACE4: i = %d, f = %g, s = %s", i, f, s);
}

运行结果:

运行结果:输出到 Event Log

可以看到这 4 个宏的运行结果是一样的。


相关:

  • C / C++ 可变参数的函数
  • C++ 可变参数的模板

C++ Builder 参考手册 ➙ C / C++ 可变参数的宏,__VA_ARGS__,...

你可能感兴趣的:(C / C++ 可变参数的宏,__VA_ARGS__,...)