0

在向 MyClass 添加 unordered_map 类型成员时发生编译错误 C2440

而 operator== 和 hash_value() 已经定义。

#include <unordered_map>
namespace MyNameSpace {
    class MyClass {
    public: 
        struct SomeArg { int x; int y; };
        typedef void (MyClass::*FUNC)(MyClass*, MyClass::SomeArg);
        struct SomeTuple { MyClass::FUNC a; int b; int c; };
        void func(MyClass* myc, MyClass::SomeArg);
    private:
        // xfunctional(768): error C2440 'type cast' cannot convert 'SomeTuple' to 'size_t'
        std::unordered_map<SomeTuple, int> someMap; 
    }; // end of MyClass
    bool operator ==(const SomeTuple& a, const SomeTuple& b);
    std::size_t hash_value(const MyClass::SomeTuple& t);
}
namespace std { // already tried moving here
    //bool operator ==(const SomeTuple& a, const SomeTuple& b) { 
    //    return (a.a==b.a && a.b==b.b && a.c==b.c); 
    //}
    //size_t hash_value(const MyNameSpace::MyClass::SomeTuple& t) {
    //    size_t seed=0; boost::hash_combine(seed, t.x); boost::hash_combine(seed, t.y);
    //}
}

我错过了什么?

4

2 回答 2

2

不是boost。您应该专门std::hash针对您的类型,或将谓词赋予map.

template <class Key,
class T,
class Hash = hash<Key>,
class Pred = std::equal_to<Key>,
class Alloc = std::allocator<std::pair<const Key, T> > >
class unordered_map;

如果你SomeTuple不在课堂上unordered_map,其中创建了 where Keyis SomeTuple——这很简单,但在其他情况下——在我看来是不可能的。

#include <unordered_map>

namespace MyNameSpace {
    struct SomeTuple { int a; int b; int c; };
}

namespace std {
template<>
struct hash<MyNameSpace::SomeTuple>
{
   size_t operator ()();
};
}

namespace MyNameSpace {
    class MyClass {
    public: 
        struct SomeArg { int x; int y; };
        void func(MyClass* myc, MyClass::SomeArg);
    private:
        // xfunctional(768): error C2440 'type cast' cannot convert 'SomeTuple' to 'size_t'
        std::unordered_map<SomeTuple, int> someMap; 
    }; // end of MyClass
    bool operator ==(const SomeTuple& a, const SomeTuple& b);
}
于 2012-10-03T11:34:32.183 回答
0

我想你的意思是这个 bool MyClass::operator==(const SomeTuple& other) const

于 2012-10-03T11:30:53.960 回答