如果我有QVector,我可以使用基于范围的循环,使用参考并更改QVector中的对象。
但是在修改对象时需要索引的情况下,我必须使用普通的for循环。但是,我怎样才能更改QVector中对象的值?
作为解决方法,我在更改临时对象后使用了替换方法,但这有点难看。
这是代码:
struct Resource {
int value = 0;
};
int main(int argc, char *argv[])
{
QVector<Resource> vector{Resource{}, Resource{}, Resource{}};
qDebug() << vector.at(0).value
<< vector.at(1).value
<< vector.at(2).value;
for(Resource &res : vector)
res.value = 1;
qDebug() << vector.at(0).value
<< vector.at(1).value
<< vector.at(2).value;
for(int i = 0; i < vector.size(); ++i) {
//Resource &res = vector.at(i); <-- won't compile: cannot convert from 'const Resource' to 'Resource &'
Resource &res = vector.value(i); //Compiles, but creates temporary Object and doesn't change the original object
res.value = i;
//vector.replace(res); <-- Workaround
}
qDebug() << vector.at(0).value
<< vector.at(1).value
<< vector.at(2).value;
}
答案 0 :(得分:3)
使用数组下标运算符[]
。
Resource &res = vector[i];
或者您可以丢弃参考变量并进行直接访问:
vector[i].value = i;
此运算符返回指定索引处对象的非const引用。
答案 1 :(得分:2)
您可以使用T & QVector::operator[](int i)
,因为它会将索引位置i
的项目作为可修改的引用返回。但是你现在正在使用const T & QVector::at(int i) const
(即在两种情况下你都有一个引用,但是在operator[]
的情况下它不是常量)。
所以,你可以这样做:
for(int i = 0; i < vector.size(); ++i)
vector[i].value = i;