c++可变参数完美转发

c++语法真的怪异

看线程源码的时候看到一段

template<class _Fn,
		class... _Args>
		explicit thread(_Fn&& _Fx, _Args&&... _Ax)
		{	// construct with _Fx(_Ax...)
		_Launch(&_Thr,
			 _STD bind(_Decay_copy(_STD forward<_Fn>(_Fx)),
				_Decay_copy(_STD forward<_Args>(_Ax))...));//后面三个...是干嘛的?难道这个方法的返回值是可变参数然后传递给
_Decay_copy()?
}

一直看不懂什么意思.....原来就是一个完美转发的包装模板,返回值其实就是可变参数,自己写了代码测试了下。

#include <iostream>

using namespace std;
template<typename T>
void printarg(T t)
{
	cout << t ;
}
template<typename ...Ts>
void go(Ts...agv){
	gogo(forward<Ts>(agv)...);  // go->gogo 可变参数转发需要...

}
template<typename ...Ts>
void gogo(Ts...agvs){
	int arr[] = { (printarg(agvs), 0)... }; //->printarg返回值赋给0,0=返回值,最后值再进入数组;
}


int main()
{
	int a = 0;
	go(1,2,3,4);//go把可变参数转发给gogo 然后gogo调用printarg()输出1,2,3,4
	getchar();
//	forward<int >(a);

}

可变参数模板是 C++11 引入的一种特性,它允许函数接受可变数量的参数。通过使用省略号(...) 和模板参数包(template parameter pack),可以在函数中定义接受任意数量和任意类型参数的参数列表。 下面是一个使用可变参数模板的示例: ```cpp #include <iostream> // 递归终止条件 void printArgs() { std::cout << "No more arguments" << std::endl; } // 打印传入的参数,并递归调用自身处理剩余参数 template<typename T, typename... Args> void printArgs(T arg, Args... args) { std::cout << arg << std::endl; printArgs(args...); } int main() { printArgs(1, "hello", 3.14, true); return 0; } ``` 输出结果: ``` 1 hello 3.14 1 No more arguments ``` 完美转发C++11 引入的另一个重要特性,它解决了在函数模板中正确传递参数的问题。在 C++中,函数传递参数时会进行类型匹配,有时可能会导致类型推导错误,或者丢失参数的引用性质。完美转发通过使用引用折叠规则(reference collapsing rules)和 std::forward 来解决这些问题。 下面是一个使用完美转发的示例: ```cpp #include <iostream> #include <utility> // 接受任意类型参数,并将其转发给其他函数 template<typename F, typename... Args> void callFunc(F&& func, Args&&... args) { std::forward<F>(func)(std::forward<Args>(args)...); } // 测试函数 void printArg(int arg) { std::cout << "Argument: " << arg << std::endl; } int main() { int x = 10; callFunc(printArg, x); // 传递参数x给printArg函数 return 0; } ``` 输出结果: ``` Argument: 10 ``` 在这个示例中,我们使用 `callFunc` 函数模板来接受任意类型的参数,并使用完美转发将这些参数传递给其他函数。在 `main` 函数中,我们将参数 `x` 传递给了 `printArg` 函数,并成功打印了参数的值。 通过使用可变参数模板和完美转发,我们可以更加灵活地处理任意数量和任意类型的参数,并确保类型推导的正确性和参数引用性质的保持。这是 C++ 中非常强大的语言特性之一。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值