std::any::emplace
Von cppreference.com
| template< class ValueType, class... Args > std::decay_t<ValueType>& emplace( Args&&... args ); |
(1) | (seit C++17) |
| template< class ValueType, class U, class... Args > std::decay_t<ValueType>& emplace( std::initializer_list<U> il, Args&&... args ); |
(2) | (seit C++17) |
Ändert das enthaltene Objekt in eines vom Typ std::decay_t<ValueType>, das aus den Argumenten konstruiert wurde.
Zuerst wird das aktuell enthaltene Objekt (falls vorhanden) mittels reset() zerstört, dann
1) wird ein Objekt vom Typ std::decay_t<ValueType> als enthaltenes Objekt konstruiert, direkt-nicht-listeninitialisiert aus std::forward<Args>(args)....
- Diese Überladung nimmt nur an der Überladungsauflösung teil, wenn std::is_constructible_v<std::decay_t<ValueType>, Args...> und std::is_copy_constructible_v<std::decay_t<ValueType>> beide true sind.
2) wird ein Objekt vom Typ std::decay_t<ValueType> als enthaltenes Objekt konstruiert, direkt-nicht-listeninitialisiert aus il, std::forward<Args>(args)....
- Diese Überladung nimmt nur an der Überladungsauflösung teil, wenn std::is_constructible_v<std::decay_t<ValueType>, std::initializer_list<U>&, Args...> und std::is_copy_constructible_v<std::decay_t<ValueType>> beide true sind.
Inhalt |
[edit] Template-Parameter
| ValueType | - | Typ des enthaltenen Wertes |
| Typanforderungen | ||
-std::decay_t<ValueType> muss die Anforderungen von CopyConstructible erfüllen. | ||
[edit] Rückgabewert
Eine Referenz auf das neu enthaltene Objekt.
[edit] Ausnahmen
Wirft jede Ausnahme, die vom Konstruktor von T geworfen wird. Wenn eine Ausnahme geworfen wird, wurde das zuvor enthaltene Objekt (falls vorhanden) zerstört, und *this enthält keinen Wert.
[edit] Beispiel
Führen Sie diesen Code aus
#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'; }
Mögliche Ausgabe
Star::Star(string, int)
Star{"Procyon" : 2943};
St6vectorIcSaIcEE
C++17[edit] Siehe auch
konstruiert ein any-Objekt(public member function) | |
| zerstört das enthaltene Objekt (public member function) |