std::inplace_vector<T,N>:: unchecked_push_back
|
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 ) ) ;
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
|
Cette section est incomplète
Raison : Expliquer l'objectif de cette API. |
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) |