我遇到的问题的最小例子如下:
#include <set>
using namespace std;
class foo {
public:
int value, x;
foo(const int & in_v) {
value = in_v;
x = 0;
}
bool operator<(const foo & rhs) const {
return value < rhs.value;
}
};
int main() {
foo y(3);
set<foo> F;
F.insert(y);
// Now try to modify a member of the set
F.begin()->x=1;
return 0;
}
Run Code Online (Sandbox Code Playgroud)
随着错误error: assignment of data-member ‘foo::value’ in read-only structure.我觉得我在这里缺少一些简单的东西,但为什么我无法修改x班上的成员?
Jam*_*lis 16
a set中的对象是不可变的; 如果要修改对象,则需要:
set,set和中删除原始对象set它看起来像这样:
std::set<int> s;
s.insert(1);
int x = *s.begin(); // (1)
x+= 1; // (2)
s.erase(s.begin()); // (3)
s.insert(x); // (4)
Run Code Online (Sandbox Code Playgroud)
小智 9
鉴于"x"变量不参与低于比较,在这种情况下,使"x"可变是安全的,允许您从集合中修改它.您的类定义将变为:
class foo {
public:
int value;
mutable int x;
foo(const int & in_v) : value(in_v), x(0) { }
bool operator<(const foo & rhs) const {
return value < rhs.value;
}
};
Run Code Online (Sandbox Code Playgroud)
您现在可以在std :: set中使用它并根据需要修改x.在这种情况下,保留数据结构的两个副本是没有意义的,如前一张海报所建议的那样.