Namespaces
Variants

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

From cppreference.net

void replace ( key_container_type && key_cont, mapped_container_type && mapped_cont ) ;
(depuis C++23)

Remplace les conteneurs sous-jacents c . Équivalent à :

c.keys = std::move(key_cont);
c.values = std::move(mapped_cont);

Les conditions suivantes doivent être remplies :

  • L'expression key_cont. size ( ) == mapped_cont. size ( ) est true ,
  • Les éléments de key_cont sont triés par rapport à compare , et
  • key_cont ne contient pas d'éléments égaux.

    Sinon, le comportement est indéfini.

Table des matières

Paramètres

keys_cont - un conteneur de clés triées de type KeyContainer , dont le contenu sera déplacé dans * this
mapped_cont - un conteneur de valeurs mappées de type MappedContainer , dont le contenu sera déplacé dans * this

Valeur de retour

(aucun)

Complexité

Équivaut à la complexité de std::move appliqué aux conteneurs adaptés.

Exemple

#include <algorithm>
#include <cassert>
#include <flat_map>
#include <print>
#include <vector>
int main()
{
    std::vector<int> keys{1, 2, 3};
    assert(std::ranges::is_sorted(keys));
    std::vector<double> values{2.2, 3.3, 1.1};
    assert(keys.size() == values.size());
    std::flat_map<int, double> map;
    assert(map.empty());
    map.replace(keys, values);
    assert(map.size() == 3);
    assert(map.keys() == 3);
    assert(map.values() == 3);
    assert(keys.empty());
    assert(values.empty());
    std::println("{}", map);
}

Sortie :

{1: 2.2, 2: 3.3, 3: 1.1}

Voir aussi

extrait les conteneurs sous-jacents
(fonction membre publique)