Namespaces
Variants

std::list<T,Allocator>:: emplace

From cppreference.net

template < class ... Args >
iterator emplace ( const_iterator pos, Args && ... args ) ;
(depuis C++11)
(constexpr depuis C++26)

Insère un nouvel élément dans le conteneur directement avant pos .

L'élément est construit via std::allocator_traits::construct , qui utilise le placement new pour construire l'élément in-situ à un emplacement fourni par le conteneur.

Les arguments args... sont transmis au constructeur sous la forme std:: forward < Args > ( args ) ... . args... peuvent faire référence directement ou indirectement à une valeur dans le conteneur.

Aucun itérateur ou référence n'est invalidé.

Table des matières

Paramètres

pos - itérateur avant lequel le nouvel élément sera construit
args - arguments à transmettre au constructeur de l'élément
Exigences de type
-
Si T n'est pas EmplaceConstructible dans list à partir de args... , le comportement est indéfini

Valeur de retour

Itérateur pointant vers l'élément inséré.

Complexité

Constante.

Exceptions

Si une exception est levée (par exemple par le constructeur), le conteneur reste inchangé, comme si cette fonction n'avait jamais été appelée (garantie d'exception forte).

Exemple

#include <iostream>
#include <string>
#include <list>
struct A
{
    std::string s;
    A(std::string str) : s(std::move(str)) { std::cout << " constructed\n"; }
    A(const A& o) : s(o.s) { std::cout << " copy constructed\n"; }
    A(A&& o) : s(std::move(o.s)) { std::cout << " move constructed\n"; }
    A& operator=(const A& other)
    {
        s = other.s;
        std::cout << " copy assigned\n";
        return *this;
    }
    A& operator=(A&& other)
    {
        s = std::move(other.s);
        std::cout << " move assigned\n";
        return *this;
    }
};
int main()
{
    std::list<A> container;
    std::cout << "construct 2 times A:\n";
    A two{"two"};
    A three{"three"};
    std::cout << "emplace:\n";
    container.emplace(container.end(), "one");
    std::cout << "emplace with A&:\n";
    container.emplace(container.end(), two);
    std::cout << "emplace with A&&:\n";
    container.emplace(container.end(), std::move(three));
    std::cout << "content:\n";
    for (const auto& obj : container)
        std::cout << ' ' << obj.s;
    std::cout << '\n';
}

Sortie :

construct 2 times A:
 constructed
 constructed
emplace:
 constructed
emplace with A&:
 copy constructed
emplace with A&&:
 move constructed
content:
 one two three

Rapports de défauts

Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.

DR Appliqué à Comportement publié Comportement corrigé
LWG 2164 C++11 il n'était pas clair si les arguments peuvent faire référence au conteneur clarifié

Voir aussi

insère des éléments
(fonction membre publique)
construit un élément en place à la fin
(fonction membre publique)