Namespaces
Variants

std::any:: emplace

From cppreference.net
Utilities library
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 :

1) construit un objet de type std:: decay_t < ValueType > , initialisé directement (non par liste) à partir de std:: forward < Args > ( args ) ... , comme objet contenu.
2) construit un objet de type std:: decay_t < ValueType > , initialisé directement (non par liste) à partir de il, std:: forward < Args > ( args ) ... , comme objet contenu.

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)