std::hash<std::variant>
Материал из cppreference.com
Определено в заголовочном файле <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>, хэш шаблона variant обычно не равен хешу содержащегося значения; это позволяет различать 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) |
Объект хеш-функции (шаблон класса) |