Jak mogę uzyskać liczbę argumentów do zmiennej funkcji szablonu?
to znaczy:
template<typename... T>
void f(const T&... t)
{
int n = number_of_args(t);
...
}
Jaki jest najlepszy sposób realizacji number_of_args
powyższego?
Jak mogę uzyskać liczbę argumentów do zmiennej funkcji szablonu?
to znaczy:
template<typename... T>
void f(const T&... t)
{
int n = number_of_args(t);
...
}
Jaki jest najlepszy sposób realizacji number_of_args
powyższego?
Odpowiedzi:
Po prostu napisz to:
const std::size_t n = sizeof...(T); //you may use `constexpr` instead of `const`
Zauważ, że n
jest to wyrażenie stałe (znane w czasie kompilacji), co oznacza, że możesz go użyć tam, gdzie potrzebne jest wyrażenie stałe, na przykład:
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);
Zauważ, że jeśli chcesz obliczyć zagregowany rozmiar spakowanych typów (w przeciwieństwie do liczby typów w paczce), musisz zrobić coś takiego:
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 > {};
następnie zrób to:
constexpr auto size = add_all< sizeof(T)... >::value;
W C ++ 17 (i nowszych) obliczanie sumy rozmiarów typów jest znacznie prostsze przy użyciu wyrażenia fold :
constexpr auto size = (sizeof(T) + ...);
Mam nadzieję, że to pomoże.
sizeof...
i constexpr
. :)
sizeof...
faktycznie zwraca liczbę argumentów, a nie łączny rozmiar wszystkich argumentów (jak sizeof
w tablicy)?
sizeof ...(T)
zwraca liczbę zapakowanych typów T
. Jeśli chcesz obliczyć zagregowany rozmiar upakowanych typów, musisz zrobić coś takiego: ideone.com/udggBk Dodałem to również w mojej odpowiedzi.
return (0 + ... + sizeof(t));
sizeof...(T)
.