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


87

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

すなわち:

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

    ...
}

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



21
@ R.MartinhoFernandes「PostYourAnswer」フォームは、ページの下部から数インチ離れています。;)
kay 2012

@ kay-SEisevilあなたのコメントの賛成票が彼より少ない理由がわかりません。
Sapphire_Brick

回答:


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
+12つのことを学びました。sizeof...およびconstexpr。:)
クイックス- MONICAは虐待WAS

1
したがって、これはsizeof...実際には引数の数を返し、すべての引数の合計ストレージサイズではありません(sizeof配列の場合のように)?
panzi 2014

@panzi:はい。sizeof ...(T)にパックされたタイプのを返しますT。パックされたタイプの集計サイズを計算する場合は、次のようにする必要があります。ideone.com / udggBk これも回答に追加しました。
ナワズ2014

@panzi:私の答えの計算は少し改善されました。
ナワズ2014

2
C ++ 17では、個々の引数タイプのサイズを計算するために、フォールド式を使用できるようになりました return (0 + ... + sizeof(t));
P0W 2016年
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.