从重载运算符[](templates?)返回不同的类型
Return different types from overloaded operator[] (templates?)
我有一个集合类,它需要使用operator[]
来访问其数据,但是返回的数据可以是许多不同的类型(从基类派生)。有没有一种方法可以使用模板,甚至其他一些不同的方法来重载返回不同类型的operator[]
。如果可能的话,我们非常感谢示例或代码片段。
也许您正在寻找类似的东西
#include <vector>
#include <iostream>
template<typename ElementType>
class SpecialCollection
{
public:
SpecialCollection(int length)
: m_contents(length)
{}
ElementType& operator[](int index)
{
return m_contents[index];
}
private:
std::vector<ElementType> m_contents;
};
// Example usage:
int main()
{
SpecialCollection<int> test(3);
test[2] = 4;
std::cout << test[1] << " " << test[2] << std::endl;
return 0;
}
看着这段代码,我问自己:为什么不直接使用std::vector
呢?但也许您想在operator[]()
方法中做更多的工作。
听起来你可以使用尾随返回类型推导,尽管我可能完全误解了你。
auto operator[](int i) -> decltype(collection[i]) {
return collection[i];
}
然后由编译器来推导返回类型,但是,当然,不能(在运行时)返回可变类型。正如您不能将它们(安全地)存储在一个集合中一样,
相关文章:
- 如何获取std::result_of函数的返回类型
- 奇怪的结构&GCC&clang(void*返回类型)
- 如何建立使用模板函数的lambda函数的尾部返回类型
- 为什么与常规GCC不同,即使有"学究性错误",MinGW-GCC也能容忍丢失的返回类型
- 在没有定义返回类型的函数中返回布尔值,并将结果保存在无错误的char编译中-为什么
- 特征::矩阵<双精度,1,3> 结构类型函数中的返回类型函数
- 函数作为模板参数,是否对返回类型强制约束
- C++中函数的向量返回类型引发错误
- 检查函数返回类型是否与STL容器类型值相同
- 为什么返回类型中需要typename?C++
- <Windows>为什么 std::thread::native_handle 返回类型为"long long unsigned int"的值,而不是 void*(又名 HANDLE)?
- 警告:在函数返回类型 [-Wignore 限定符] 时忽略类型限定符
- 为什么 c++(g++) 不允许模板返回类型和函数名称之间有空格?
- 为什么返回类型的'const'限定符对标有 __forceinline/内联的函数没有影响?
- 推导 std::vector::back() 的返回类型
- 在 c++ 中将函数返回类型指定为模板参数
- 使用 SWIG 更改生成的 CS 函数中的返回类型
- QtQuick - qml:28:错误:未知方法返回类型:自定义类型
- 基于返回类型的转换和过载扣除
- 当返回类型声明为 ListNode 时,我们是否可以返回 false<T>*