Namespaces
Variants
Views
Actions

std::flat_multimap<Key,T,Compare,KeyContainer,MappedContainer>::extract

From cppreference.com
 
 
 
 
containers extract() &&;
(since C++23)

Extracts adapted containers. *this is emptied, even if an exception is thrown. Equivalent to return std::move(c);.

Contents

[edit] Parameters

(none)

[edit] Return value

std::move(c), i.e. the underlying containers.

[edit] Complexity

Constant.

[edit] 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]

[edit] See also

replaces the underlying containers
(public member function) [edit]