std::hash<std::variant>

来自cppreference.com
< cpp‎ | utility‎ | variant
 
 
工具库
语言支持
类型支持(基本类型、RTTI)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
变参数函数
调试支持
(C++26)
三路比较
(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::hashstd::variant 模板的模板特化允许用户获得 variant 对象的散列值。

若启用 std::hash<std::remove_const_t<Types>>... 中的每个特化,则启用特化 std::hash<std::variant<Types...>>(见 std::hash),否则禁用它。

不保证此特化的成员函数为 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)
散列函数对象
(类模板)