std::inplace_vector<T,N>:: unchecked_emplace_back
|
template
<
class
...
Args
>
constexpr reference unchecked_emplace_back ( Args && ... args ) ; |
(depuis C++26) | |
Ajoute un nouvel élément à la fin du conteneur. Généralement, l'élément est construit en utilisant le placement- new pour construire l'élément in-situ à l'emplacement fourni par le conteneur. Les arguments args... sont transmis au constructeur sous la forme std:: forward < Args > ( args ) ... . Équivalent à return * try_emplace_back ( std:: forward < Args > ( args ) ... ) ; .
Avant l'appel à cette fonction 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
| args | - | arguments à transmettre au constructeur de l'élément |
| Exigences de type | ||
-
T
doit être
EmplaceConstructible
dans
inplace_vector
à partir de
std::
forward
<
Args
>
(
args
)
...
.
|
||
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, cette fonction n'a aucun effet ( garantie forte de sûreté face aux exceptions ).
Notes
|
Cette section est incomplète
Motif : Expliquer l'objectif de cette API. |
Exemple
#include <inplace_vector> #include <new> #include <print> #include <string> #include <utility> int main() { std::inplace_vector<std::pair<std::string, std::string>, 2> fauna; std::string dog{"\N{DOG}"}; fauna.unchecked_emplace_back("\N{CAT}", dog); fauna.unchecked_emplace_back("\N{CAT}", std::move(dog)); std::println("fauna = {}", fauna); // fauna.unchecked_emplace_back("BUG", "BUG"); // comportement indéfini : pas d'espace }
Sortie :
fauna = [("🐈", "🐕"), ("🐈", "🐕")]
Voir aussi
|
construit un élément en place à la fin
(fonction membre publique) |
|
|
ajoute une plage d'éléments à la fin
(fonction membre publique) |
|
|
ajoute un élément à 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) |
|
|
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) |