可变参模板

可变参模板,第1张

可变参模板的英文为Variadic Templates,是c++11标准引入的。可变参模板允许模板定义中含有0到多个模板参数。
有如下普通函数的例子

void myptfunc(int a)
{
cout<<a<<" ";
}

看看可变参模板

void MyFunc()
{

}

template<typename T,typename...U>
void MyFunc(T fistarg,U... otherargs)
{
	cout << fistarg << " ";
	MyFunc(otherargs...);

}

int main()
{
	MyFunc(1,2,5,"hello");
	system("pause");
	return 0;
}

结果:

注意template行的写法typename…U,后面带3个点代表参数包,然后才修饰U。对于void MyFunc(T fistarg,U… otherargs),因为U带了…,所以将U称为可变参类型,看起来是一个类型名,实际上其中包含的是0到多个不同的类型(一包类型)。

对于这样的可变参函数模板有一个问题,就是在获得一包参数之后,程序员的我们必须要把这一包参数逐个拿到手处理,也就是如何将参数包展开?

对于这种可变参函数模板,展开的套路是比较固定的,一般都是用递归函数的方式展开参数包。为了实现用递归函数的方式展开参数包,就要求在可变参函数模板的代码中,有一个参数展开函数和一个同名的递归终止函数。这个递归终止函数(不是一个函数模板),一般都是不带参数的同名函数。

在c++17标准中增加了 一个语句:编译期间if语句,改写如下:

template<typename T,typename...U>
void MyFunc(T fistarg,U... otherargs)
{
	cout << fistarg << " ";
	if constexpr(sizeof...(otherargs)>0)
	{
		MyFunc(otherargs...);
	}
	
}

这样就不用递归终止函数了。sizeof…属于固定语法,是c++11引入的,用于可变参数模板或可变参数模板内部,用来表示收到的模板参数个数或类型数量,针对的只能是这种…的可变参。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1295391.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-10
下一篇 2022-06-10

发表评论

登录后才能评论

评论列表(0条)

保存