Вывод шаблона размера массива
У меня есть класс, в котором хранится std::array
.
Размер массива оценивается во время компиляции, это связано с тем, что приложение работает на встроенном устройстве, поэтому нет динамических распределений:(. Код выглядит примерно так:
template<uint8_t size>
class A
{
//some constructor
A(...);
std::array<int, size> what;
}
//Wanted use cases
A instance1({1,2,3});
//Unwanted use case
A<3> instance2({1,2,3});
Я не знаю, как построить нужный мне конструктор. За неделю я перепробовал десятки дизайнов, и ни один не получил того, что хотел. Вот названия вещей, которые я пробовал:
- Руководства по выводу шаблонов - также шаблонные версии, которые я не уверен, законны ли они...
std::initializer_list
- размер списка нельзя указать в аргументе шаблона. По крайней мере, не в контексте без constexpr.std::array
- простой старый массив
using
ключевое слово - тоже шаблонное.
Tl;Dr:
Как вывести значение параметра шаблона, обозначающее размер типа массива, из данного массива в сигнатуре функции-конструктора?
2 ответа
Решение
Небольшой пример с использованием руководств по дедукции:
template<uint8_t size>
class A
{
public:
template <typename... Args>
constexpr A(Args&&... args)
: what { std::forward<decltype(args)>(args)... }
{}
constexpr size_t getSize() const { return what.size(); }
private:
std::array<int, size> what;
};
//deduction guide
template <typename... Args> A(Args... args) -> A<sizeof...(args)>;
int main()
{
//Wanted use cases
A instance1 (1,2,3);
static_assert (instance1.getSize() == 3);
//or
//A instance1 {1,2,3};
return 0;
}
#include <array>
template<class... U>
class A
{
std::array<int,sizeof...(U)> what;
public:
constexpr A(U&&... u) : what{std::forward<U>(u)...} { }
constexpr std::size_t size() const {
return what.size();
}
};
int main() {
A a(1,2,3,4,5,6);
static_assert(a.size() == 6);
A b(1);
static_assert(b.size() == 1);
return 0;
}