专业的std ::哈希私有成员类

问题描述 投票:3回答:2

我有一个类(称之为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使this answer朋友结构,但没有工作,要么:Outer::Inner的向前声明失败:

error: use of undeclared identifier 'Outer'

所以,我应该如何着手(如果我打算做的是有可能的话)?

c++ c++11 hash unordered-set stdhash
2个回答
4
投票

因为它是一个私有内部类,我认为你在封闭类privateprotected std::unordered_map成员。如果是这样的话,只写一个私有内部散列函数对象,并把它作为了std::unordered_map的第三个参数。这是你的问题的最简单的方法,我想。


8
投票

得到它了 !解决的办法是使用自己的函子,并不是专门的std ::哈希值。

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;
};
© www.soinside.com 2019 - 2024. All rights reserved.