为私有成员类专门化std::hash
Specializing std::hash for private member class
我有一个类(称为Outer
),它有一个私有成员类(Inner
)。我想将Outer::Inner
的实例存储在无序的标准容器中,所以我想专门化std::hash<Outer::Inner>
。
然而,在写这篇文章时:
namespace std {
template<>
struct hash<Outer::Inner> {
std::size_t operator()(const Outer::Inner &arg) const
{
return std::hash<int>()(arg.someSpecialProperty);
}
};
}
编译器抱怨:
error: 'Inner' is a private member of 'Outer'
std::size_t operator()(const Outer::Inner &p) const
^
我曾试图通过以下答案使std::hash
成为一个友元结构,但这也不起作用:Outer::Inner
的前向声明失败:
error: use of undeclared identifier 'Outer'
那么,我应该如何进行(如果我打算做的事情是可能的)?
明白了!解决方案是使用您自己的函数,而不是专门化std::hash。
struct A
{
A() { v.insert(std::make_pair(B(1), 6)); }
private:
struct B
{
B(int i = 0) : m_i(i) { }
int m_i;
};
struct HashB { std::size_t operator()(const B& b) const { return b.m_i; } };
struct EqualB { bool operator()(const B&b1, const B&b2) const { return b1.m_i == b2.m_i; } };
std::unordered_map<B, int, HashB, EqualB> v;
};
由于它是一个私有内部类型,我假设封闭类中有一个private
或protected
std::unordered_map
成员。如果是这种情况,只需编写一个私有的内部散列函子,并将其作为std::unordered_map
的第三个参数传递。我认为这是解决你问题最简单的方法。
相关文章:
- C++std::hash实现总是确定性的吗
- std::hash for std::chrono::duration
- 为什么不区分大小写适用于 std::unordered_set的 std::hash 函数?
- 错误:未使用不完整的类型'struct std::hash<>'无效
- 无法专门化 std::hash 以unordered_map存储自定义类型
- 为模板类嵌套类定义 std::hash 时出现编译错误
- Return value of std::hash ofr (x86/x64)
- STD :: HASH :: operator() - 例外保证
- STD :: HASH专业化仍然由STD :: Unordered_map未使用
- C++11:是否有理由为什么某些常规类型不应该专门使用“std::hash”
- 重新定义 std::hash 模板结构
- 为什么std::hash不专门用于std::reference_wrapper
- std::hash 是否保证在 stdlib 发行版中相同
- 专门针对类满足条件的“std::hash”
- 如何使用 std::hash 对缓冲区进行哈希处理
- 为类模板的枚举成员定义 std::hash
- 无法对指向成员使用 std::hash 的专用化
- c++11 std::hash函数对象类的线程安全性
- 我可以重写std::hash吗
- const和nonconst类型的部分std::hash专用化