Namensräume
Varianten
Aktionen

std::any::emplace

Von cppreference.com
< cpp‎ | utility‎ | any
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
 
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)....
2) wird ein Objekt vom Typ std::decay_t<ValueType> als enthaltenes Objekt konstruiert, direkt-nicht-listeninitialisiert aus il, std::forward<Args>(args)....

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

#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) [edit]
zerstört das enthaltene Objekt
(public member function) [edit]