Предположим, у меня есть функция шаблона с переменным числом аргументов, например
template<typename... Args>
unsigned length(Args... args);
Как найти длину списка параметров с помощью функции длины?
Предположим, у меня есть функция шаблона с переменным числом аргументов, например
template<typename... Args>
unsigned length(Args... args);
Как найти длину списка параметров с помощью функции длины?
Используйте 1_:
template<typename... Args>
constexpr std::size_t length(Args...)
{
return sizeof...(Args);
}
Обратите внимание, что вы должны использовать не unsigned
, а std::size_t
(определено в <cstddef>
). Кроме того, функция должна быть константным выражением.
Без использования sizeof...
:
namespace detail
{
template<typename T>
constexpr std::size_t length(void)
{
return 1; // length of 1 element
}
template<typename T, typename... Args>
constexpr std::size_t length(void)
{
return 1 + length<Args...>(); // length of one element + rest
}
}
template<typename... Args>
constexpr std::size_t length(Args...)
{
return detail::length<Args...>(); // length of all elements
}
Обратите внимание, все полностью не проверено.
sizeof ...
может возвращать 0. 14.3/1: Когда параметр, объявленный шаблоном, представляет собой пакет параметров шаблона (14.5.3), он будет соответствовать нулю или более аргументам шаблона.
- person Potatoswatter; 05.05.2010
length<>
, ответить не могу. Может быть, избежать перегрузок здесь.
- person Potatoswatter; 05.05.2010
template<typename ... T> constexpr typename enable_if<sizeof...(T)==0, std::size_t>::type length(void) { return 0; }
, но я согласен - лучше использовать для этого шаблон класса.
- person Johannes Schaub - litb; 06.05.2010