std::hash<std::variant>
Von cppreference.com
| 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
Führen Sie diesen Code aus
#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) |