web-dev-qa-db-ja.com

C ++ 11:可変長テンプレート関数パラメーターの数?

可変個引数テンプレート関数の引数の数を取得するにはどうすればよいですか?

すなわち:

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

    ...
}

上記のnumber_of_argsを実装する最良の方法は何ですか?

75
Andrew Tomazos

これを書いてください:

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);

numberパック内のタイプのパックされたタイプの集約サイズを計算したい場合は、何かをする必要があることに注意してくださいこのような:

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 expressionを使用すると、型のサイズの合計を計算するのがはるかに簡単になります。

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

お役に立てば幸いです。

88
Nawaz