object作为unordered_map的键

时间:2011-04-16 08:20:12

标签: c++ unordered-map

我将类的对象放在无序映射中作为键有问题 这是一个简单的例子:

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显示此行为。

任何帮助将不胜感激!这对我的项目很有帮助......

2 个答案:

答案 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;
}