在unordered_map中插入元素会产生错误

时间:2013-01-09 18:09:52

标签: c++ vector unordered-map

我已经定义了unordered_map这样的

struct pht {
  pht(int t, vector<bool> pat) 
: tag(t), pattern(32) {}
private:
  int tag;
  vector<bool> pattern;
};

unordered_map< pair<int, int>, pht > predictor;

int main()
{
  int pc, addr, offset, tag;
  vector<bool> pat;
  srand(time(0));

  tag = 1000; pc = 100; offset = 10; 
  for ( int i = 0; i < 32; i++ ) 
  pat.push_back( rand() % 2 );
  predictor.insert(make_pair( make_pair(pc, offset), pht(tag, pat) ) );
  return 0;
}

但是我收到了这个错误:

(修订版)

error C2440: 'type cast' : cannot convert from 'const std::pair<_Ty1,_Ty2>' to 'size_t' 

我该如何解决?

1 个答案:

答案 0 :(得分:5)

错误消息具有误导性;真正的原因是std::hash要求std::pair<int, int>没有unordered_map专门化。您需要提供此专业化或(推荐)创建unordered_map来指定自定义哈希:

struct hash_pair {
    template <typename T, typename U>
    std::size_t operator ()(std::pair<T, U> const& p) const {
        using std::hash;
        return hash<T>()(p.first) ^ hash<T>()(p.second);
    }
};

然后将地图声明为:

unordered_map<pair<int, int>, pht, hash_pair> predictor;