Comment puis-je obtenir un décompte du nombre d'arguments d'une fonction de modèle variadique?
c'est à dire:
template<typename... T>
void f(const T&... t)
{
int n = number_of_args(t);
...
}
Quelle est la meilleure façon de mettre number_of_args
en œuvre ce qui précède?
c++
c++11
variadic-templates
variadic-functions
Andrew Tomazos
la source
la source
sizeof...(T)
.Réponses:
Écrivez simplement ceci:
const std::size_t n = sizeof...(T); //you may use `constexpr` instead of `const`
Notez qu'il
n
s'agit d'une expression constante (c'est-à-dire connue au moment de la compilation), ce qui signifie que vous pouvez l'utiliser là où une expression constante est nécessaire, comme: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);
Notez que si vous souhaitez calculer la taille agrégée des types compressés (par opposition au nombre de types dans le pack), alors vous devez faire quelque chose comme ceci:
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 > {};
puis faites ceci:
constexpr auto size = add_all< sizeof(T)... >::value;
En C ++ 17 (et versions ultérieures), le calcul de la somme des tailles des types est beaucoup plus simple à l'aide de l' expression fold :
constexpr auto size = (sizeof(T) + ...);
J'espère que ça t'as aidé.
la source
sizeof...
etconstexpr
. :)sizeof...
renvoie en fait le nombre d'arguments et non la taille de stockage combinée de tous les arguments (commesizeof
le ferait un tableau)?sizeof ...(T)
renvoie le nombre de types emballésT
. Si vous voulez calculer la taille agrégée des types emballés, vous devez faire quelque chose comme ceci: ideone.com/udggBk J'ai également ajouté ceci dans ma réponse.return (0 + ... + sizeof(t));