看不懂C++11模板函数参数推导
Can't understand C++11 template function parameter deduction
template <int T> struct int2type{};
template<int I>
void func( int2type<I> )
{
printf("int_val: %in", I);
}
int main(int argc, char *argv[])
{
func( int2type<10>() );
}
当然要打印10。
我对模板和类型扣除的工作原理有一些基本概念,但是我不了解此代码。I
背后的魔力是什么?我们如何从int2type
实例中知道I
传递给func
?
模板参数扣除由C 14标准的部分[temp.deduct.call]涵盖。它太大了,无法完全复制,但要旨是编译器将将参数类型int2type<10>
与参数类型int2type<I>
进行比较,并尝试找到I
的值,以使两者相同。
在[temp.deduct.type]/9和/17中指定的是,参数 class-template-name<i>
,其中 i
是一个非类型模板参数,与参数 class-template-name<n>
匹配,其中 n
是同一类型的参数。
相关文章:
- 将可变参数函数的参数封装在类实例中
- QML 使用带有参数C++函数
- 使用可变参数函数作为模板参数
- 如何在C++中伪造虚拟可变参数函数模板?
- 为什么可变参数函数不适用于模板
- C++ std::functional 中的可变参数函数模板
- 可变参数函数指针的定义对于VxWorks spyLib来说不清楚
- 使用可变参数函数覆盖具有不同函数签名的虚函数
- 考虑引用和常量的可变参数函数包装器
- 使用可变参数函数将整数和/或整数数组放入单个 int 数组中
- 在可变参数函数中转发特定范围的参数
- 通过引用传递参数;函数返回类型是否必须为 VOID?
- 使用带有一个参数函数的递归找到数字的平方
- 可变参数函数模板不能很好地使用 std::function 作为参数
- 多个可变参数函数的单个模板参数包?
- 参数数据类型未知的可变参数函数
- 可变参数函数参数包扩展
- 使用模板可变参数函数将多个参数传递给另一个函数
- 对可变参数函数的递归调用的链接器错误
- 通过像printf这样的可变参数函数传递一个带有常量字符*转换函数的类