std::hash(std::basic_string)

来自cppreference.com
< cpp‎ | string‎ | basic string
 
 
 
std::basic_string
成员函数
元素访问
迭代器
容量
操作
搜索
常量
推导指引 (C++17)
非成员函数
I/O
比较
(C++20 前)(C++20 前)(C++20 前)(C++20 前)(C++20 前)(C++20)
数值转换
(C++11)(C++11)(C++11)
(C++11)(C++11)    
(C++11)(C++11)(C++11)
(C++11)
(C++11)
辅助类
hash<std::string>hash<std::wstring>hash<std::u32string>hash<std::u16string>hash<std::u8string>
(C++11)  (C++11)(C++11)(C++11)(C++20)
hash<std::pmr::string>hash<std::pmr::wstring>hash<std::pmr::u32string>hash<std::pmr::u16string>hash<std::pmr::u8string>
(C++17)(C++17)(C++17)(C++17)(C++20)
 
在标头 <string> 定义
template< class A >

struct hash<std::basic_string<char, std::char_traits<char>, A>>;
template< class A >
struct hash<std::basic_string<char16_t, std::char_traits<char16_t>, A>>;
template< class A >
struct hash<std::basic_string<char32_t, std::char_traits<char32_t>, A>>;
template< class A >

struct hash<std::basic_string<wchar_t, std::char_traits<wchar_t>, A>>;
(C++11 起)
template< class A >
struct hash<std::basic_string<char8_t, std::char_traits<char8_t>, A>>;
(C++20 起)

std::hash 对各种字符串类的模板特化允许用户获得字符串的哈希。

这些哈希等于对应 std::basic_string_view 类的哈希:若 S 是这些字符串类型之一, SV 是对应的字符串视图类型,而 sS 类型的对象,则 std::hash<S>()(s) == std::hash<SV>()(SV(s))

(C++17 起)

示例

下列代码显示 string 上使用的散列函数的一种可能输出:

#include <iostream>
#include <string>
#include <string_view>
#include <functional>
#include <memory_resource>
using namespace std::literals;
 
int main()
{
    auto sv = "Stand back! I've got jimmies!"sv;
    std::string s(sv);
    std::pmr::string pmrs(sv); // 使用默认分配器
 
    std::cout << std::hash<std::string_view>{}(sv) << '\n';
    std::cout << std::hash<std::string>{}(s) << '\n';
    std::cout << std::hash<std::pmr::string>{}(pmrs) << '\n';
}

可能的输出:

3544599705012401047
3544599705012401047
3544599705012401047

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 3705 C++11 未启用带有自定义分配器的 std::basic_string 的散列支持 已启用

参阅

(C++11)
散列函数对象
(类模板)
string_view 的散列支持
(类模板特化)