Как упоминалось в других ответах, невозможно добавить какую-либо функцию-член к типу std
, например std::tuple
. И operator[]
должен быть нестатической c функцией-членом.
Но вы можете обернуть этот кортеж - и добавить operator[]
к этому типу оболочки. В таком случае вам необходимо знать общий тип возвращаемого значения для всех элементов кортежа. Что ж, есть std :: any, который может работать с большинством типов.
Это должно сработать, но это только для удовлетворения вашего любопытства - было бы плохим дизайном использовать что-то подобное в реальном программном обеспечении:
template <typename Tuple, typename ReturnType = std::any>
class TupleExtractor
{
public:
TupleExtractor(const Tuple& tuple)
: TupleExtractor(tuple, std::make_index_sequence<std::tuple_size_v<Tuple>>{})
{}
ReturnType operator[](std::size_t index) const
{
return extractors[index](tuple);
}
private:
template <std::size_t I>
static ReturnType get(const Tuple& tuple)
{
return std::get<I>(tuple);
}
template <std::size_t ...I>
TupleExtractor(const Tuple& tuple, std::index_sequence<I...>)
: tuple(tuple),
extractors{&TupleExtractor::get<I>...}
{}
const Tuple& tuple;
using Extractor = std::any(*)(const Tuple&);
std::vector<Extractor> extractors;
};
и проверьте - что работает:
int main() {
std::tuple<int, int, int> a{1,2,3};
TupleExtractor e{a};
return std::any_cast<int>(e[2]);
}