如何散列std::string_view?
How to hash std::string_view?
我正在尝试为 std::unordered_map
定义我自己的散列函数,我想散列结构中的一个字段,该结构应该是键。下面的代码是我所拥有的代码的简化版本:
struct TestStruct {
char a[64];
char b[64];
}
struct my_eq {
bool operator()(const TestStruct& test_1, const TestStruct& test_2) const {
return !strcmp(test_1.a, test_2.a) && !strcmp(test_1.b, test_2.b);
}
};
struct my_hash {
unsigned long operator()(const TestStruct& test) const {
return std::hash<std::string_view>(std::string_view(test.a));
}
};
std::unordered_map<TestStruct, int, my_hash,my_eq> map;
我得到的错误是:
no matching function for call to ‘std::hash<std::basic_string_view<char> >::hash(std::string_view&)
根据cppreference on std::hash
哈希函数应该支持std::string_view
。我觉得我缺少一些简单的东西,但我无法弄清楚。
std::hash
是 class 模板, 不是 函数模板。你需要一个实例来调用它:
return std::hash<std::string_view>()(std::string_view(test.a));
您使用的 std::hash
有误。 std::hash
是一个 class,它提供了一个 operator()
来散列对象。您正试图将对象传递给它的构造函数,这不起作用,因为它只有一个默认的构造函数。您的 operator()
也需要标记为 const
。我们将所有这些放在一起,我们得到:
struct my_hash {
unsigned long operator()(const TestStruct& test) const {
return std::hash<std::string_view>()(std::string_view(test.a));
}
};
我正在尝试为 std::unordered_map
定义我自己的散列函数,我想散列结构中的一个字段,该结构应该是键。下面的代码是我所拥有的代码的简化版本:
struct TestStruct {
char a[64];
char b[64];
}
struct my_eq {
bool operator()(const TestStruct& test_1, const TestStruct& test_2) const {
return !strcmp(test_1.a, test_2.a) && !strcmp(test_1.b, test_2.b);
}
};
struct my_hash {
unsigned long operator()(const TestStruct& test) const {
return std::hash<std::string_view>(std::string_view(test.a));
}
};
std::unordered_map<TestStruct, int, my_hash,my_eq> map;
我得到的错误是:
no matching function for call to ‘std::hash<std::basic_string_view<char> >::hash(std::string_view&)
根据cppreference on std::hash
哈希函数应该支持std::string_view
。我觉得我缺少一些简单的东西,但我无法弄清楚。
std::hash
是 class 模板, 不是 函数模板。你需要一个实例来调用它:
return std::hash<std::string_view>()(std::string_view(test.a));
您使用的 std::hash
有误。 std::hash
是一个 class,它提供了一个 operator()
来散列对象。您正试图将对象传递给它的构造函数,这不起作用,因为它只有一个默认的构造函数。您的 operator()
也需要标记为 const
。我们将所有这些放在一起,我们得到:
struct my_hash {
unsigned long operator()(const TestStruct& test) const {
return std::hash<std::string_view>()(std::string_view(test.a));
}
};