std::flat_multimap<Key,T,Compare,KeyContainer,MappedContainer>::extract
From cppreference.com
< cpp | container | flat multimap
C++
Feature test macros (C++20)
Concepts library (C++20)
Metaprogramming library (C++11)
Ranges library (C++20)
Filesystem library (C++17)
Concurrency support library (C++11)
Execution control library (C++26)
Containers library
(C++17)
(C++11)
(C++26)
(C++26)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++23)
(C++23)
(C++23)
(C++23)
(C++20)
(C++23)
Tables
std::flat_multimap
flat_multimap::extract
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.
Contents
[edit] Return value
std::move(c).
[edit] Complexity
Constant.
[edit] Example
Run this code
#include <cassert> #include <flat_map> #include <print> #include <type_traits> #include <utility> #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{std::move(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.values), std::vector <double>>); std::println ("keys: {}", c.keys); std::println ("values: {}", c.values); }
Output:
keys: [1, 2, 3] values: [1.1, 2.2, 3.3]