std::flat_map<Key,T,Compare,KeyContainer,MappedContainer>:: key_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
|
key_compare key_comp
(
)
const
;
|
(начиная с C++23)
(constexpr начиная с C++26) |
|
Возвращает функциональный объект, сравнивающий ключи, который является копией объекта сравнения ключей, используемого * this .
Содержание |
Возвращаемое значение
Объект функции сравнения ключей.
Сложность
Константа.
Пример
Запустить этот код
#include <iostream> #include <flat_map> #include <utility> // Пример функции сравнения ключей по модулю 97 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.key_comp(); for (const auto it : cont) { const bool before = comp_func(it.first, 100); const bool after = comp_func(100, it.first); std::cout << "Ключ (" << it.first << ',' << it.second << ") "; if (!before && !after) std::cout << "эквивалентен ключу (100)\n"; else if (before) std::cout << "предшествует ключу (100)\n"; else if (after) std::cout << "следует после ключа (100)\n"; else std::unreachable(); } }
Вывод:
(1,a) предшествует ключу (100) (2,b) предшествует ключу (100) (3,c) эквивалентен ключу (100) (4,d) следует после ключа (100) (5,e) следует после ключа (100)
Смотрите также
возвращает функцию, которая сравнивает ключи в объектах типа
value_type
(публичная функция-член) |