函数参数包的行为
Behavior of a function parameter pack
template<typename... T>
void foo(T... args);
在上述示例中,T
根据标准的§14.5.3-(4.1(进行扩展。
§14.5.3.(4.1(——在功能参数包(8.3.5(中;模式是不带省略号的参数声明。
这里到底发生了什么?假设我用3个整数调用函数。
foo(1, 2, 3);
参数包是否像一样扩展
foo(int arg1, int arg2, int arg3);
其中arg1、arg2和arg3只是编译器给定的任意名称?
标准规定了"模式是没有省略号的参数声明">
我解释的另一种方式是args
得到一个单独的参数声明。args
得到自己的类型吗?我试过做
std::cout << typeid(args).name;
但这不起作用,并引发编译器错误。所以我可以假设它没有得到自己的类型。有人会"沉默"这里到底发生了什么,以及函数参数包的行为吗?
好吧,我想我已经想通了。如果我错了,请纠正我。
当省略号位于模式的右侧时,将进行参数扩展。我们这里的模式只是T
:
foo(T... args);
标准规定,这样做的结果将是parameter-declaration
。这衰减为:
属性说明符seqoptdecl说明符seq声明符
CCD_ 6可以忽略。
decl-specifier-seq
是类型,T
;
declarator
是... args
从语义上讲,这是一个函数参数包声明。没什么特别的。
再一次,我的好奇心让我有点疯狂。。。呵呵。
相关文章:
- 将可变参数函数的参数封装在类实例中
- QML 使用带有参数C++函数
- 使用可变参数函数作为模板参数
- 如何在C++中伪造虚拟可变参数函数模板?
- 为什么可变参数函数不适用于模板
- C++ std::functional 中的可变参数函数模板
- 可变参数函数指针的定义对于VxWorks spyLib来说不清楚
- 使用可变参数函数覆盖具有不同函数签名的虚函数
- 考虑引用和常量的可变参数函数包装器
- 使用可变参数函数将整数和/或整数数组放入单个 int 数组中
- 在可变参数函数中转发特定范围的参数
- 通过引用传递参数;函数返回类型是否必须为 VOID?
- 使用带有一个参数函数的递归找到数字的平方
- 可变参数函数模板不能很好地使用 std::function 作为参数
- 多个可变参数函数的单个模板参数包?
- 参数数据类型未知的可变参数函数
- 可变参数函数参数包扩展
- 使用模板可变参数函数将多个参数传递给另一个函数
- 对可变参数函数的递归调用的链接器错误
- 通过像printf这样的可变参数函数传递一个带有常量字符*转换函数的类