标准::数组<std::array<T、N2>、N> 数据成员上的括号运算符重载
Brackets operator overload on std::array<std::array<T, N2>, N> data member
因此,考虑以下代码:
#include <iostream>
#include <array>
template<class T, std::size_t N, std::size_t N2>
struct foo
{
std::array<std::array<T, N2>, N> data;
T& operator[](std::size_t index) { return data[index]; }
};
int main()
{
foo<int, 3, 3> obj;
std::cout << obj[2][2]; //boom
}
这是我的逻辑:obj[2]
本身返回一个std::array<T, N2>
对象,因此再次将operator[]
应用于该对象(obj[2][2]
),应该会得到我需要的结果。实际上,对于obj[2]
,它调用foo
的operator[]
,而对于obj[2][2]
,它调用的是std::array<T, N>
的operator[]
。显然不是。
问题:上例中发生了什么,为什么我的逻辑有问题?
operator[]
的返回类型不对。表达式data[index]
的类型为std::array<T, N2>
,并且您告诉编译器您返回了一个T&
,这是false。你的功能应该是这样的:
std::array<T, N2>& operator[](std::size_t index) { return data[index]; }
查看您的operator[]
。它返回T&
,在您的情况下是int&
。另一方面,data[index]
是类型std::array<T, N2>&
,在这种情况下是std::array<int, 3>&
。
更改操作员的返回类型应解决以下问题:
std::array<T, N2>& operator[](std::size_t index) { return data[index]; }
相关文章:
- 请解释这句话(cout<<1+int((a<b)^((b-a)&1) )<<endl
- 呼叫运营商<<临时
- 如何防止clang格式在流运算符调用之间添加换行符<<
- <<操作员在下面的行中工作
- EASTL矢量<向量<int>>连续的
- C - 创建矢量&lt; vector&lt; double&gt;&gt;矩阵具有分配而不是inizializ
- 为什么将此对向量&lt; map&lt; int,int&gt;&gt;中的地图进行更新.失败
- C :对矢量进行排序&lt; struct&gt;(结构有2个整数)基于结构的整数之一
- 明确的专业化“ CheckIntmap&lt;&gt;”实例化
- 什么是模板&lt;&gt;inline bla bla
- 编辑C Qlist&lt; object*&gt; gt;QML代码和一些QML警告中的模型
- eigen :: llt&lt;eigen :: matrixxd&gt;具有不完整的类型
- 错误,包括&lt; ctype&gt;在原子上使用C 11
- std::vector<;uint8_t>;当C++11/14启用时,手动复制而不是调用memcpy
- 如何加入向量&lt; int&gt;到C 中的单个INT
- 是std :: set&lt; std :: future&gt;不可能存在
- 是numeric_limits&lt; int&gt; :: is_modulo从逻辑上矛盾
- opencv 2.4.7在iOS错误背景_segm.hpp #include&lt; list&gt;未找到
- 在修改列表后,std :: list&lt; t&gt; :: end()的值是否会更改
- ///<评论></评论>在Visual Studio中