一、可变宏参数
在GNU C中,宏可以接受可变数目的参数,就象函数一样,例如:
#define pr_debug(fmt,arg...) \
printk(KERN_DEBUG fmt, ##arg)
用可变参数宏(variadic macros)传递可变参数表
你可能很熟悉在函数中使用可变参数表,如:
void printf(const char* format, ...);
C99编译器标准终于改变了这种局面,它允许你可以定义可变参数宏(variadic macros),这样你就可以使用拥有可以变化的参数表的宏。可变参数宏就像下面这个样子:
#define debug(...) printf(__VA_ARGS__)
CPP使用一个特殊的’##’操作。书写格式为:## __VA_ARGS__ 这个运算符把两个语言符号组合成单个语言符号,为宏扩展提供了一种连接实际变元的手段
使用中:
二、容器列表initializer_list 缺点参数列表类型必须相同类型,适应性较差。使用简单
头文件:#include <initializer_list>
int sum(initializer_list<int> il) {
int sum = 0;
for (auto p = il.begin(); p != il.end(); ++p) {
sum += *p;
}
return sum;
}
int ret = sum({1, 2, 3, 4, 5, 6});
三、可变参数模板
template <typename T>
std::ostream &print(std::ostream &os, const T &t) {
return os << t << endl; //包中最后一个元素
}
//包中除最后一个元素之外的其他元素都会调用这个版本的pirnt
template <typename T, typename... Args>
std::ostream &print(std::ostream &os, const T &t, const Args &... rest) {
os << t << ","; //打印第一个实参,包中元素减一
return print(os, rest...); //递归调用,打印剩余实参
}
使用:
print(cout, "yes or no", ret,true);