Namespaces
Variants

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

From cppreference.net

void push_back ( const T & value ) ;
(1) (constexpr depuis C++26)
void push_back ( T && value ) ;
(2) (depuis C++11)
(constexpr depuis C++26)

Ajoute une copie de value à la fin du conteneur.

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

Table des matières

Paramètres

value - la valeur de l'élément à ajouter

Exigences de type
-
Si la condition suivante est remplie, le comportement est indéfini :
1) T n'est pas CopyInsertable dans list .
2) T n'est pas MoveInsertable dans list .
(depuis C++11)

Complexité

Constante.

Exceptions

Si une exception est levée (ce qui peut être dû à Allocator::allocate() ou au constructeur/opérateur d'affectation de copie/déplacement d'élément), cette fonction n'a aucun effet ( garantie d'exception forte ).

Exemple

#include <iomanip>
#include <iostream>
#include <string>
#include <list>
int main()
{
    std::list<std::string> letters;
    letters.push_back("abc");
    std::string s{"def"};
    letters.push_back(std::move(s));
    std::cout << "std::list letters holds: ";
    for (auto&& e : letters)
        std::cout << std::quoted(e) << ' ';
    std::cout << "\nMoved-from string s holds: " << std::quoted(s) << '\n';
}

Sortie possible :

std::list letters holds: "abc" "def"
Moved-from string s holds: ""

Voir aussi

construit un élément en-place à la fin
(fonction membre publique)
insère un élément au début
(fonction membre publique)
supprime le dernier élément
(fonction membre publique)
crée un std::back_insert_iterator du type déduit de l'argument
(fonction template)