Namespaces
Variants

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

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

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

Si size ( ) == capacity ( ) est true , il n'y a aucun effet. Sinon, ajoute un objet de type T :

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

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 EmplaceConstructible .

Valeur de retour

std:: addressof ( back ( ) ) si size ( ) < capacity ( ) , nullptr sinon.

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> pets;
    std::string dog{"dog"};
    std::string* p1 = pets.try_push_back("cat"); // surcharge (1)
    assert(*p1 == "cat" and pets.size() == 1);
    std::string* p2 = pets.try_push_back(std::move(dog)); // surcharge (2)
    assert(*p2 == "dog" and pets.size() == 2);
    assert(pets[0] == "cat" and pets[1] == "dog");
    assert(pets.size() == pets.capacity());
    std::string* p3 = pets.try_push_back("bug");
    assert(p3 == nullptr and pets.size() == 2);
}

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 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)
ajoute inconditionnellement un élément à 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)