在C++11中出现的变参模板,可以让我们不需关心函数调用的参数多少,类似实现C中的printf函数那样。
变参依赖于C++强大的模板
可以这样声明
template<class T1,class... Args> // Args就是一种类型参数包,在定义的函数中需要递归去解析
void MutiArg(const T1&t1,Args... args)
{
// do something with t1对第一个调用参数进行操作
MutiArg(args...); //对参数包进行递归解析,这个函数会一直调用直到其参数个数为1时停止调用
}
当参数个数被解析到只有一个时调用下边的函数
template<class T1>
void MutiArg(const T1&t1)
{
//do something with t1
}
下面直接上测试的完整例子
#incldue<iostream>
#include<string>
template<class T1, class... Args>
void MutiArg(const T1&t1, Args... args)
{
std::cout << t1 << std::endl;
MutiArg(args...);
}
template<class T>
void MutiArg(const T& t)
{
std::cout << "t=" << t << std::endl;
std::cout << "end" << std::endl;
}
void main()
{
MutiArg(1,1.2,3,"string",‘c‘);
}
其运行结果为
1
1.2
3
string
c
--------------end
时间: 2024-10-10 10:52:53