std:: hash <std::variant>
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Member functions | ||||
| Observers | ||||
| Modifiers | ||||
| Visitation | ||||
|
(C++26)
|
||||
| Non-member functions | ||||
| Helper classes | ||||
|
hash
<std::variant>
|
||||
| Helper objects | ||||
|
Определено в заголовочном файле
<variant>
|
||
|
template
<
class
...
Types
>
struct hash < std:: variant < Types... >> ; |
(начиная с C++17) | |
Специализация шаблона
std::hash
для шаблона
std::variant
позволяет пользователям получать хеши объектов
variant
.
Специализация
std::hash
<
std::
variant
<
Types...
>>
включена (см.
std::hash
), если включена каждая специализация в
std::hash
<
std::
remove_const_t
<
Types
>>
...
, и отключена в противном случае.
Функции-члены этой специализации не гарантируют noexcept.
Содержание |
Параметры шаблона
| Types | - |
типы альтернатив, поддерживаемых объектом
variant
|
Примечания
В отличие от std::hash<std::optional> , хеш варианта обычно не равен хешу содержащегося значения; это позволяет различать std:: variant < int , int > , содержащий одинаковые значения в качестве различных альтернатив.
Пример
#include <iostream> #include <string> #include <variant> using Var = std::variant<int, int, int, std::string>; template<unsigned I> void print(Var const& var) { std::cout << "get<" << var.index() << "> = " << std::get<I>(var) << "\t" "# = " << std::hash<Var>{}(var) << '\n'; } int main() { Var var; std::get<0>(var) = 2020; print<0>(var); var.emplace<1>(2023); print<1>(var); var.emplace<2>(2026); print<2>(var); var = "C++"; print<3>(var); }
Возможный вывод:
get<0> = 2020 # = 2020 get<1> = 2023 # = 2024 get<2> = 2026 # = 2028 get<3> = C++ # = 15518724754199266859
Смотрите также
|
(C++11)
|
функциональный объект хеш-функции
(шаблон класса) |