在Visual '12中获取以下编译错误
error C3867: 'std::vector<_Ty>::at': function call missing argument list; use '&std::vector<_Ty>::at' to create a pointer to member line 39码
Vector2dVector mVertices;
/// other code
for (int pointIndex = 0; pointIndex < points.size(); pointIndex++) {
mVertices.push_back(Vector2d(pointIndex * 2.0f, pointIndex * 3.0f ));
}
int size = mVertices.size();
CCPoint *pointArr = new CCPoint[size];
for(int i = 0; i < size; i++) {
Vector2d vec2 = mVertices.at[i]; //Line 39
//pointArr[i].x = vec2->GetX();
//pointArr[i].y = vec2->GetY();
}发布于 2013-04-11 09:41:48
问题是这里有一个错误:
Vector2d vec2 = mVertices.at[i]; //Line 39
^ ^应该将()与std::vector::at方法调用一起使用,而不是[]。
Vector2d vec2 = mVertices.at(i); //Line 39 另一种选择可以是使用std::vector::operator[]重载(而不是at()):
Vector2d vec2 = mVertices[i];区别在于std::vector::at()对向量索引执行边界检查,并在索引超出范围时抛出异常std::out_of_range (防止缓冲区溢出)。
相反,如果使用std::vector::operator[],则禁用边界检查。
换句话说,使用std::vector::operator[]可以获得更快的代码,但没有对向量索引进行运行时检查(因此必须注意索引,以避免缓冲区溢出)。
(更准确地说,在Visual中,如果_SECURE_SCL设置为1,也会对std::vector::operator[]进行边界检查)。
发布于 2013-04-11 09:29:59
Vector2d vec2 = mVertices.at(i);
// ^ ^你需要括号,而不是括号。at是一个成员函数。
发布于 2013-04-11 09:30:09
Vector2dVector::at很可能是一个函数,而不是一个类型数组的字段:
Vector2d vec2 = mVertices.at(i); //Line 39 https://stackoverflow.com/questions/15945236
复制相似问题