如何获得可变参数模板函数的参数数量?
即:
template<typename... T>
void f(const T&... t)
{
int n = number_of_args(t);
...
}
实施number_of_args
上述最佳方法是什么?
如何获得可变参数模板函数的参数数量?
即:
template<typename... T>
void f(const T&... t)
{
int n = number_of_args(t);
...
}
实施number_of_args
上述最佳方法是什么?
Answers:
只需写下:
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) + ...);
希望能有所帮助。
sizeof...
和constexpr
。:)
sizeof...
实际上返回的是参数的数量,而不是所有参数的组合存储大小(就像sizeof
在数组上一样)吗?
return (0 + ... + sizeof(t));
sizeof...(T)
。