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