我将类的对象放在无序映射中作为键有问题 这是一个简单的例子:
class first
{
string name;
public:
first(){}
first(string nam):name(nam){}
string get_name() const
{
return name;
}
};
struct SampleTraits
{
size_t operator()(const first &that) const
{
return tr1::hash<const char*>()(that.get_name().c_str());
}
bool operator()(const first &t1,const first &t2) const
{
return t1.get_name()==t2.get_name();
}
};
typedef tr1::unordered_set<unsigned short> uset;
typedef tr1::unordered_map<first,uset,SampleTraits,SampleTraits> umap;
ostream& operator <<(ostream& out, uset &ust)
{
for(uset::iterator it=ust.begin();it!=ust.end();++it)
out<<" "<<*it;
}
int main()
{
umap *mymap= new umap;
string names,nm,n;
cout<<"\nEnter 1st name: ";
cin>>names;
first obj(names);
(*mymap)[obj].insert(100);
(*mymap)[obj].insert(120);
(*mymap)[obj].insert(112);
cout<<"\nEnter 2nd name:";
cin>>nm;
first obj2(nm);
(*mymap)[obj2].insert(201);
(*mymap)[obj2].insert(202);
cout<<"\nEnter name which u want to search:";
cin>>n;
first obj1(n);
umap::iterator it=mymap->find(obj1);
cout<<it->first.get_name();
cout<<it->second;
//delete mymap;
/*
for(umap::iterator it=mymap->begin();it!=mymap->end();it++)
{
cout<<it->first.get_name()<<" ";
cout<<it->second<<endl;
}
*/
return 0;
}
我的问题是,当我尝试插入两个不同的对象并试图显示它是显示分段错误..再次如果我尝试使用find()然后它也显示分段错误..我很难理解为什么unordered_map显示此行为。
任何帮助将不胜感激!这对我的项目很有帮助......
答案 0 :(得分:4)
问题在于哈希函数。它不像您期望的那样使用指针类型,因为它使用指针来计算哈希值而不是其内容。使用std :: string可以解决问题。
return tr1::hash<string>()(that.get_name());
答案 1 :(得分:0)
看起来你忘了从运营商&lt;&lt;&lt;&lt;&lt;用于使用。虽然,大多数编译器都会对这些函数发出警告,但仍然需要编译它们,运行这样的程序会导致未定义的行为。
ostream& operator <<(ostream & out, uset & ust)
{
for(uset::iterator it=ust.begin();it!=ust.end();++it)
out<<" "<<*it;
return out;
}