我正在学习 C++,但无法解决这个问题:
我有一个简单的A类
class A {
private:
int ival;
float fval;
public:
A(int i = 0, float f = 0.0) : ival(i), fval(f) { }
~A(){ }
void show() const {
cout << ival << " : " << fval << "\n";
}
void setVal(int i) {
ival = i;
}
//const getters for both ival and fval
//used for the default "lesser"
friend bool operator<(const A& val1, const A& val2) {
return val1.ival < val2.ival ? true : false;;
}
}
然后我有一个普通的set<A> myset
充满了 insert(A(2, 2.2));
在一个循环中。
迭代获取所有值不是问题,但我想在此迭代中修改值:
for(set<A>::iterator iter = set3.begin(); iter != set3.end(); iter++) {
iter->setVal(1);
}
我认为这应该是可行的,就像您在 Java 中的 foreach 循环中那样。编译时我得到 error: passing ‘const A’ as ‘this’ argument of ‘void A::setVal(int)’ discards qualifiers
.
查看 STL 集的来源,我看到 begin()
只能作为常量方法使用,我认为这可能是问题所在。在 setVal()
上使用 const方法总是得到相同的错误并且没有多大意义,因为我想修改 A
的值.
这是不是改一堆A
的错误做法?带有循环的值?
最佳答案
STL 集不允许您更改它存储的值。它通过迭代器返回对象的拷贝(而不是集合中的实际拷贝)来实现这一点。
set 这样做的原因是因为它使用 < 对 set 进行排序,并且它不想在每次取消引用迭代器时重新创建整个树,而它必须这样做,因为它不知道是否你改变了任何改变顺序的东西。
如果您需要更新集合<>,请删除旧值并添加新值。
编辑:刚刚检查了 SGI STL 的源代码,它是这样说的:
typedef typename _Rep_type::const_iterator iterator;
所以,一个 set::iterator 就是一个 set::const_iterator
关于c++ - 通过迭代器更改类成员,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3467997/