std::flat_map<Key,T,Compare,KeyContainer,MappedContainer>:: value_comp
From cppreference.net
C++
Containers library
|
(C++17)
|
||||
| Sequence | ||||
|
(C++11)
|
||||
|
(C++26)
|
||||
|
(C++26)
|
||||
|
(C++11)
|
||||
| Associative | ||||
| Unordered associative | ||||
|
(C++11)
|
||||
|
(C++11)
|
||||
|
(C++11)
|
||||
|
(C++11)
|
||||
| Adaptors | ||||
|
(C++23)
|
||||
|
(C++23)
|
||||
|
(C++23)
|
||||
|
(C++23)
|
||||
| Views | ||||
|
(C++20)
|
||||
|
(C++23)
|
||||
| Tables | ||||
| Iterator invalidation | ||||
| Member function table | ||||
| Non-member function table |
std::flat_map
|
value_compare value_comp
(
)
const
;
|
(seit C++23)
(constexpr seit C++26) |
|
Gibt ein Funktionsobjekt zurück, das Objekte vom Typ
value_type
(Schlüssel-Wert-Paare) vergleicht, indem
key_comp()
verwendet wird, um die ersten Komponenten der Paare zu vergleichen.
Inhaltsverzeichnis |
Rückgabewert
Das Wertvergleichsfunktionsobjekt.
Komplexität
Konstante.
Beispiel
Diesen Code ausführen
#include <iostream> #include <flat_map> #include <utility> // Beispiel-Modul-97-Schlüsselvergleichsfunktion struct ModCmp { bool operator()(int lhs, int rhs) const { return (lhs % 97) < (rhs % 97); } }; int main() { std::flat_map<int, char, ModCmp> cont; cont = {{1, 'a'}, {2, 'b'}, {3, 'c'}, {4, 'd'}, {5, 'e'}}; auto comp_func = cont.value_comp(); for (const std::pair<int, char> val = {100, 'a'}; auto it : cont) { const bool before = comp_func(it, val); const bool after = comp_func(val, it); std::cout << '(' << it.first << ',' << it.second << ") "; if (!before && !after) std::cout << "equivalent to key (" << val.first << ")\n"; else if (before) std::cout << "goes before key (" << val.first << ")\n"; else if (after) std::cout << "goes after key (" << val.first << ")\n"; else std::unreachable(); } }
Ausgabe:
(1,a) goes before key (100) (2,b) goes before key (100) (3,c) equivalent to key (100) (4,d) goes after key (100) (5,e) goes after key (100)
Siehe auch
|
gibt die Funktion zurück, die Schlüssel vergleicht
(öffentliche Elementfunktion) |