当我尝试将元素插入到unordered_set中时,我收到此错误:
error: invalid operands to binary expression ('const Play' and 'const Play')
{return __x == __y;}
以下是整个错误的屏幕截图: https://www.dropbox.com/s/nxq5skjm5mvzav3/Screenshot%202013-11-21%2020.11.24.png
这是我的哈希函数:
struct Hash {
size_t operator() (Play &play) {
unsigned long hash = 5381;
int c;
string s_str = play.get_defense_name() + play.get_offense_name() + play.get_description();
const char * str = s_str.c_str();
while ( (c = *str++) )
hash = ((hash << 5) + hash) + c; /* hash * 33 + c */
cout << hash << endl;
return hash;
}
};
这是我声明unordered_list的地方:
unordered_set<Play, Hash> Plays;
这是我的==
课程的重载Play
:
friend bool operator== (Play& p1, Play& p2)
{
return
(p1.get_defense_name() == p2.get_defense_name()) &&
(p1.get_offense_name() == p2.get_offense_name()) &&
(p1.get_description() == p2.get_description());
}
知道这里会发生什么吗?
感谢。
答案 0 :(得分:5)
该错误表示它尝试将const Play
与const Play
进行比较,但您只为operator ==
提供Play
friend bool operator== (const Play& p1, const Play& p2)
{
return
(p1.get_defense_name() == p2.get_defense_name()) &&
(p1.get_offense_name() == p2.get_offense_name()) &&
(p1.get_description() == p2.get_description());
}
答案 1 :(得分:2)
看起来无序集正在寻找比较常量Play
对象,但是你的==
提供了比较非常量对象。由于不允许删除const-ness,编译器会产生错误。添加常量可以解决问题:
friend bool operator== (const Play& p1, const Play& p2)
您还应该const
添加operator()
:
size_t operator() (const Play &play)