std::hash<std::string_view>, std::hash<std::wstring_view>, std::hash<std::u8string_view>, std::hash<std::u16string_view>, std::hash<std::u32string_view>
出自cppreference.com
| 在標頭 <string_view> 定義
|
||
| |
(C++17 起) | |
| |
(C++17 起) | |
| |
(C++20 起) | |
| |
(C++17 起) | |
| |
(C++17 起) | |
std::hash 對各種視圖類的模板特化,目的是求視圖的散列。
這些散列值等於對應的 std::basic_string 類的散列值:若 S 是標準 basic_string 類型之一,SV 是對應的字符串視圖類型,且 s 是 S 類型的對象,則 std::hash<S>()(s) == std::hash<SV>()(SV(s))。
示例
運行此代碼
#include <iostream>
#include <string_view>
#include <unordered_set>
using namespace std::literals;
int main()
{
std::cout << "\"A\" #: " << std::hash<std::string_view>{}("A"sv) << '\n';
std::cout << "L\"B\" #: " << std::hash<std::wstring_view>{}(L"B"sv) << '\n';
std::cout << "u8\"C\" #: " << std::hash<std::u8string_view>{}(u8"C"sv) << '\n';
std::cout << "u\"D\" #: " << std::hash<std::u16string_view>{}(u"D"sv) << '\n';
std::cout << "U\"E\" #: " << std::hash<std::u32string_view>{}(U"E"sv) << '\n';
// 为 string_view 族提供的 std::hash 使得这些视图类型可以在如 unordered_set 这样的
// unordered_* 关联容器中保留。但应确保所引用的字符串生存期不短于容器的生存期,即不发生悬垂引用。
std::unordered_set stars{"Rigel"sv, "Capella"sv, "Vega"sv, "Arcturus"sv};
for (std::string_view const& s : stars)
std::cout << s << ' ';
std::cout << '\n';
}
可能的輸出:
"A" #: 6919333181322027406
L"B" #: 11959850520494268278
u8"C" #: 12432341034569643010
u"D" #: 312659256970442235
U"E" #: 18073225910249204957
Arcturus Vega Capella Rigel
參閱
(C++11) |
散列函數對象 (類模板) |
(C++11) |
字符串的散列支持 (類模板特化) |