C ++ 11:可变参数模板函数参数的数量?


87

如何获得可变参数模板函数的参数数量?

即:

template<typename... T>
void f(const T&... t)
{
    int n = number_of_args(t);

    ...
}

实施number_of_args上述最佳方法是什么?


28
sizeof...(T)
R. Martinho Fernandes

21
@ R.MartinhoFernandes,“发布答案”表单离页面底部几英寸。;)
kay 2012年

@ kay-SEisevil我不明白为什么您的评论比他的评论少。
Sapphire_Brick

Answers:


103

只需写下:

const std::size_t n = sizeof...(T); //you may use `constexpr` instead of `const`

请注意,这n是一个常量表达式(即在编译时已知),这意味着您可以在需要常量表达式的地方使用它,例如:

std::array<int,   n>  a; //array of  n elements
std::array<int, 2*n>  b; //array of (2*n) elements

auto middle = std::get<n/2>(tupleInstance);

请注意,如果要计算打包类型的聚合大小(而不是打包中的类型数量),则必须执行以下操作:

template<std::size_t ...>
struct add_all : std::integral_constant< std::size_t,0 > {};

template<std::size_t X, std::size_t ... Xs>
struct add_all<X,Xs...> : 
  std::integral_constant< std::size_t, X + add_all<Xs...>::value > {};

然后这样做:

constexpr auto size = add_all< sizeof(T)... >::value;

在C ++ 17(及更高版本)中,使用fold表达式计算类型大小的总和要简单得多:

constexpr auto size = (sizeof(T) + ...);

希望能有所帮助。


9
+1学会了两件事;sizeof...constexpr。:)
Qix-蒙尼卡(Monica)

1
因此,这sizeof...实际上返回的是参数的数量,而不是所有参数的组合存储大小(就像sizeof在数组上一样)吗?
panzi 2014年

@panzi:是的。sizeof ...(T)返回包装在中的类型T。如果要计算打包类型的聚合大小,则必须执行以下操作:ideone.com/udggBk 我也在答案中也添加了此内容。
纳瓦兹2014年

@panzi:我的答案中的计算现在已略有改善。
纳瓦兹

2
使用C ++ 17,现在可以使用fold表达式来计算单个arg类型的大小 return (0 + ... + sizeof(t));
P0W 2016年
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.