Namespaces
Variants

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

From cppreference.net

containers extract ( ) && ;
(desde C++23)

Extrae los contenedores adaptados c . Equivalente a return std :: move ( c ) ; .

Después de esta operación * this está vacío, incluso si se lanza una excepción.

Contenidos

Valor de retorno

std :: move ( c ) .

Complejidad

Constante.

Ejemplo

#include <cassert>
#include <flat_map>
#include <print>
#include <type_traits>
#include <utility>
#include <vector>
int main()
{
    std::flat_map<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());
    // Los contenedores predeterminados para claves y valores son 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);
}

Salida:

keys: [1, 2, 3]
values: [1.1, 2.2, 3.3]

Véase también

reemplaza los contenedores subyacentes
(función miembro pública)