В данном задании вам нужно реализовать свою версию кортежа
— std::tuple
.
Что нужно реализовать для tuple<Types...>
:
- Конструктор по умолчанию — производит value-инициализацию каждого элемента;
- Все специальные члены класса, которые посчитаете нужными (должны сохранять тривиальность);
- Конструктор от
UTypes&&...
— инициализирует элементы заданными значениями; - Конструктор от
const Types&...
— помогает предыдущему с выводом типов; make_tuple
— создаётtuple
, сам выводя типы. Обратите внимание, как он это делает в случае с ссылками (см. cppref);- Обращение к элементам:
get<N>
— возвращает значение по заданному индексу;get<T>
— возвращает значение по заданному типу (если он встречается несколько раз, должна быть ошибка компиляции);
- Операторы сравнения (
==
,<=>
) в лексикографическом порядке — определены только для кортежей одинакового размера; - Вспомогательные трейты:
tuple_size<T>
,tuple_size_v<T>
— количество элементов в кортежеT
;tuple_element<N, T>
,tuple_element_t<N, T>
— типN
-го элемента в кортежеT
.
Пример:
tuple<int, double, int> x {42, 3.14, 1337};
get<0>(x); // ok: 42
get<2>(x); // ok: 1337
get<double>(x); // ok: 3.14
get<3>(x); // compilation error
get<char>(x); // compilation error
get<int>(x); // compilation error
Любые операции должно быть можно исполнить во время компиляции. Где считаете
нужными, расставьте noexcept
и explicit
(возможно, условные).