Namensräume
Varianten
Aktionen

std::hash<std::variant>

Von cppreference.com
< cpp‎ | utility‎ | variant
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
 
Definiert in der Header-Datei <variant>
template< class... Types >
struct hash<std::variant<Types...>>;
(seit C++17)

Die Template-Spezialisierung von std::hash für die std::variant Template ermöglicht es Benutzern, Hash-Werte von variant Objekten zu erhalten.

Die Spezialisierung std::hash<std::variant<Types...>> ist aktiviert (siehe std::hash), wenn jede Spezialisierung in std::hash<std::remove_const_t<Types>>... aktiviert ist, und ist andernfalls deaktiviert.

Es gibt keine Garantie, dass die Member-Funktionen dieser Spezialisierung noexcept sind.

Inhalt

[edit] Template-Parameter

Typen - die Typen der Alternativen, die vom variant-Objekt unterstützt werden

[edit] Hinweise

Im Gegensatz zu std::hash<std::optional> ist der Hash eines Variants nicht typischerweise gleich dem Hash des enthaltenen Wertes; dies ermöglicht es, std::variant<int, int> mit demselben Wert, aber unterschiedlichen Alternativen zu unterscheiden.

[edit] Beispiel

#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);
}

Mögliche Ausgabe

get<0> = 2020   # = 2020
get<1> = 2023   # = 2024
get<2> = 2026   # = 2028
get<3> = C++    # = 15518724754199266859

[edit] Siehe auch

(C++11)
Hash-Funktionsobjekt
(Klassenvorlage) [edit]