Пространства имён
Варианты
Действия

std::hash<std::variant>

Материал из cppreference.com
< cpp‎ | utility‎ | variant
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
Общие утилиты
Дата и время
Функциональные объекты
Библиотека форматирования (C++20)
(C++11)
Операторы отношения (устарело в C++20)
Целочисленные функции сравнения
(C++20)(C++20)(C++20)    
(C++20)
Операции обмена и типа
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Общие лексические типы
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
 
Определено в заголовочном файле <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)
Объект хеш-функции
(шаблон класса) [править]