无法对指向成员使用 std::hash 的专用化
Unable to Use Specialization of std::hash for Pointer-to-Member?
我假设std::hash对通用指针类型的专用化可以用于指向成员的指针,但是我不能这样使用它;相反,我的编译器给了我一个"不完整的类型"错误,我认为这意味着'不使用std::hash的专用化来表示指针?这是怎么回事?
#include <functional>
struct foo{
void bar(int a){}
};
int main(){
std::hash<void (foo::*)(int)> hasher;
}
错误:
..srcm.cpp:43:32: error: aggregate 'std::hash<void (foo::*)(int)> hasher' has incomplete type and cannot be defined
问题是指向成员的指针并不是真正的指针;它们只是碰巧具有相似的名称和相似的语法。 std::hash
专门用于普通指针,但不用于指向成员的指针。你当然可以自己专门化它,但如果有一种方法可以保证安全,我看不到它;除了取消引用它或将其强制转换为指向成员的其他指针之外,您无法对指向成员的指针执行太多操作。
将
结构声明更改为:
struct foo{
static void bar(int a){}
};
非静态成员函数有一个与 this 指针对应的隐藏参数,这就是编译器发生的原因。
您必须先定义专用化,然后才能使用它。
namespace std
{
template <>
struct std::hash<void (foo::*)(int)>
{
// Implement the class.
};
}
使用它。
int main(){
std::hash<void (foo::*)(int)> hasher;
}
相关文章:
- 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专用化