std::flat_multimap<Key,T,Compare,KeyContainer,MappedContainer>:: extract
Sequence | ||||
(C++11)
|
||||
(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 |
Member types | ||||
Member functions | ||||
Non-member functions | ||||
Helper classes | ||||
Tags | ||||
Deduction guides |
containers extract
(
)
&&
;
|
(since C++23) | |
Extracts adapted containers
c
. Equivalent to
return
std
::
move
(
c
)
;
.
After this operation * this is empty, even if an exception is thrown.
Parameters
(none)
Return value
std :: move ( c ) .
Complexity
Constant.
Example
#include <cassert> #include <flat_map> #include <print> #include <type_traits> #include <vector> int main() { std::flat_multimap<int, double> map{{1, 1.1}, {2, 2.2}, {3, 3.3}}; const auto size = map.size(); auto c = map.extract(); assert(c.keys.size() == size); assert(c.values.size() == size); assert(map.empty()); assert(map.keys().empty()); assert(map.values().empty()); // The default keys and values containers are std::vector: static_assert(std::is_same_v<decltype(c.keys), std::vector<int>>); static_assert(std::is_same_v<decltype(c.value), std::vector<int>>); std::println("keys: {}", c.keys); std::println("values: {}", c.values); }
Output:
keys: [1, 2, 3] values: [1.1, 2.2, 3.3]
See also
replaces the underlying containers
(public member function) |