如何解决包装散列函数返回包装类型的散列
#include <bits/stdc++.h>
using namespace std;
// wrapper class on type E
template <typename E>
class g {
public:
E val;
g(E x) : val(x) {};
};
// hash for g<E> should be hash for E
template<typename E> struct std::hash<g<E>> {
std::size_t operator()(const ::g<E> &t) const {
return std::hash<E>()(t);
}
};
int main() {
ios_base::sync_with_stdio(false); cin.tie(nullptr);
unordered_set<g<int>>{g<int>(3)};
}
基本上,这个想法是我有一个围绕模板类型的包装器,我希望能够在 unordered_set/map 中使用这个包装器类。但我收到以下错误:
no match for call to '(std::hash<int>) (const g<int>&)'
。这很奇怪——c++ 没有实现这个哈希吗?我做错了什么?
解决方法
您的代码试图在 std::hash<int>()
上调用 t
,其类型为 g<int>
。您需要“解开”包装器并在封闭的 std::hash<int>()
上调用 int
:
return std::hash<E>()(t.val);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。