Namespaces
Variants

std:: hash <std::variant>

From cppreference.net
Utilities library
定義済みヘッダー <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)
ハッシュ関数オブジェクト
(クラステンプレート)