std::any:: emplace
|
template
<
class
ValueType,
class
...
Args
>
std:: decay_t < ValueType > & emplace ( Args && ... args ) ; |
(1) | (depuis C++17) |
|
template
<
class
ValueType,
class
U,
class
...
Args
>
std:: decay_t < ValueType > & emplace ( std:: initializer_list < U > il, Args && ... args ) ; |
(2) | (depuis C++17) |
Modifie l'objet contenu en un objet de type std:: decay_t < ValueType > construit à partir des arguments.
Détruit d'abord l'objet contenu actuel (s'il existe) via reset() , puis :
- Cette surcharge participe à la résolution de surcharge seulement si std:: is_constructible_v < std:: decay_t < ValueType > , Args... > et std:: is_copy_constructible_v < std:: decay_t < ValueType >> sont tous deux true .
- Cette surcharge participe à la résolution de surcharge seulement si std:: is_constructible_v < std:: decay_t < ValueType > , std:: initializer_list < U > & , Args... > et std:: is_copy_constructible_v < std:: decay_t < ValueType >> sont tous deux true .
Table des matières |
Paramètres du modèle
| ValueType | - | type de valeur contenu |
| Exigences de type | ||
-
std::decay_t<ValueType>
doit satisfaire aux exigences de
CopyConstructible
.
|
||
Valeur de retour
Une référence au nouvel objet contenu.
Exceptions
Lance toute exception levée par le constructeur de
T
. Si une exception est levée, l'objet précédemment contenu (s'il y en avait un) a été détruit, et
*
this
ne contient pas de valeur.
Exemple
#include <algorithm> #include <any> #include <iostream> #include <string> #include <vector> class Star { std::string name; int id; public: Star(std::string name, int id) : name{name}, id{id} { std::cout << "Star::Star(string, int)\n"; } void print() const { std::cout << "Star{\"" << name << "\" : " << id << "};\n"; } }; int main() { std::any celestial; // (1) emplace(Args&&... args); celestial.emplace<Star>("Procyon", 2943); const auto* star = std::any_cast<Star>(&celestial); star->print(); std::any av; // (2) emplace(std::initializer_list<U> il, Args&&... args); av.emplace<std::vector<char>>({'C', '+', '+', '1', '7'} /* no args */); std::cout << av.type().name() << '\n'; const auto* va = std::any_cast<std::vector<char>>(&av); std::for_each(va->cbegin(), va->cend(), [](char const& c) { std::cout << c; }); std::cout << '\n'; }
Sortie possible :
Star::Star(string, int)
Star{"Procyon" : 2943};
St6vectorIcSaIcEE
C++17
Voir aussi
construit un objet
any
(fonction membre publique) |
|
|
détruit l'objet contenu
(fonction membre publique) |