这似乎是一个愚蠢的问题,但当我试图在SOF中查看这个答案时,
我注意到这样的陈述:
template<
typename IntType, std::size_t Cols,
IntType(*Step)(IntType),IntType Start, std::size_t ...Rs
>
constexpr auto make_integer_matrix(std::index_sequence<Rs...>)
{
return std::array<std::array<IntType,Cols>,sizeof...(Rs)>
{{make_integer_array<IntType,Step,Start + (Rs * Cols),Cols>()...}};
}
更具体地说:
std::size_t ...Rs
或
std::index_sequence<Rs...>
这意味着什么?
报告为与此问题相关的原始问题的问题不正确:
该问题无法回答这两种情况(因为它们不是具有可变数量参数的函数)
std::size_t ...Rs
std::index_sequence<Rs...>
但这是一个很好的解释:
https://xenakios.wordpress.com/2014/01/16/c11-the-three-dots-that-is-variadic-templates-part/
答案 0 :(得分:14)
它被称为参数包,并引用零个或多个模板参数:
http://en.cppreference.com/w/cpp/language/parameter_pack
std::size_t ...Rs
是std::size_t
类型的参数包。
该类型的变量(例如Rs... my_var
)可以用以下内容解压缩:
my_var...
这种模式大量用于转发(未知)数量的参数:
template < typename... T >
Derived( T&&... args ) : Base( std::forward< T >( args )... )
{
}