Namespaces
Variants

std::flat_set<Key,Compare,KeyContainer>:: replace

From cppreference.net

void replace ( container_type && cont ) ;
(depuis C++23)

Remplace le conteneur sous-jacent c . Équivalent à : c = std :: move ( cont ) ; .

Les éléments de cont doivent être triés par rapport à compare , et cont ne doit pas contenir d'éléments égaux. Sinon, le comportement est indéfini.

Table des matières

Paramètres

cont - un conteneur trié de type KeyContainer , dont le contenu sera déplacé dans * this

Valeur de retour

(aucun)

Complexité

Équivaut à la complexité de std::move appliqué au conteneur adapté.

Exemple

#include <algorithm>
#include <cassert>
#include <flat_set>
#include <print>
#include <vector>
int main()
{
    std::vector<int> keys{1, 2, 3};
    assert(std::ranges::is_sorted(keys));
    std::flat_set<int> set;
    assert(set.empty());
    set.replace(keys);
    assert(set.size() == 3);
    assert(keys.empty());
    std::println("{}", set); // set.keys()
}

Sortie :

[1, 2, 3]

Voir aussi

extrait le conteneur sous-jacent
(fonction membre publique)