重载元组索引运算符-C++
Overload tuple indexing operator - C++
如何为std::tuple<int,int,int>
重载索引[]
运算符?因此,当我有std::tuple<int,int,int> tup
并键入tup[0]
时,我希望它返回对get<0>(tup)
的引用。这可能吗?
如其他答案中所述,不可能像std::tuple
那样向std
类型添加任何成员函数。并且operator[]
必须是非静态成员函数。
但是您可以包装这个元组,并将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]);
}
这是不可能的,原因有二:
-
operator[]
必须是非静态成员函数,并且由于您没有实现标准库,因此无法向std::tuple
添加成员函数。 -
索引必须是常量表达式,不能用函数参数强制执行。
相关文章:
- 为什么比较运算符如此快速
- C++映射:具有自定义类的运算符[]不起作用(总是返回0)
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 增量运算符与后缀混淆
- 一个关于在C++中重载布尔运算符的问题
- 运算符C++ "delete []"仅删除 2 个前值
- 模板类无法识别友元运算符
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 关闭||运算符优化
- 通过继承类使用来自不同命名空间的运算符
- C++Cast运算符过载
- 如何使用AngelScript注册SFML Vector2运算符
- 重载元组索引运算符-C++
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- 布尔比较运算符是如何在C++中工作的
- 重载运算符new[]的行为取决于析构函数
- 如何防止clang格式在流运算符调用之间添加换行符<<