Namespaces
Variants

std::inplace_vector<T,N>:: unchecked_push_back

From cppreference.net
constexpr reference unchecked_push_back ( const T & value ) ;
(1) (depuis C++26)
constexpr reference unchecked_push_back ( T && value ) ;
(2) (depuis C++26)

Ajoute l'élément donné value à la fin du conteneur.

Équivalent à : return * try_push_back ( std:: forward < decltype ( value ) > ( value ) ) ;

1) Le nouvel élément est initialisé en tant que copie de value .
2) value est déplacé dans le nouvel élément.

Avant l'appel à ces fonctions size ( ) < capacity ( ) doit être true . Sinon, le comportement est indéfini.

Aucun itérateur ou référence n'est invalidé, à l'exception de end() , qui est invalidé si l'insertion se produit.

Table des matières

Paramètres

value - la valeur de l'élément à ajouter
Exigences de type
-
T doit satisfaire aux exigences de CopyInsertable pour utiliser la surcharge (1).
-
T doit satisfaire aux exigences de MoveInsertable pour utiliser la surcharge (2).

Valeur de retour

back() , c'est-à-dire une référence à l'élément inséré.

Complexité

Constante.

Exceptions

Toute exception levée par l'initialisation de l'élément inséré.

Si une exception est levée pour quelque raison que ce soit, ces fonctions n'ont aucun effet ( strong exception safety guarantee ).

Notes

Exemple

#include <cassert>
#include <inplace_vector>
#include <string>
int main()
{
    std::inplace_vector<std::string, 2> fauna;
    std::string dog{"dog"};
    auto& r1 = fauna.unchecked_push_back("cat"); // surcharge (1)
    assert(r1 == "cat" and fauna.size() == 1);
    auto& r2 = fauna.unchecked_push_back(std::move(dog)); // surcharge (2)
    assert(r2 == "dog" and fauna.size() == 2);
    assert(fauna[0] == "cat" and fauna[1] == "dog");
    // fauna.unchecked_push_back("bug"); // comportement indéfini : il n'y a plus d'espace
}

Voir aussi

ajoute un élément à la fin
(fonction membre publique)
construit un élément en-place à la fin
(fonction membre publique)
ajoute une plage d'éléments à la fin
(fonction membre publique)
tente d'ajouter un élément à la fin
(fonction membre publique)
tente de construire un élément en-place à la fin
(fonction membre publique)
tente d'ajouter une plage d'éléments à la fin
(fonction membre publique)
construit inconditionnellement un élément en-place à la fin
(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)