Namespaces
Variants

std::any:: emplace

From cppreference.net
Utilities library
template < class ValueType, class ... Args >
std:: decay_t < ValueType > & emplace ( Args && ... args ) ;
(1) (desde C++17)
template < class ValueType, class U, class ... Args >
std:: decay_t < ValueType > & emplace ( std:: initializer_list < U > il, Args && ... args ) ;
(2) (desde C++17)

Cambia el objeto contenido a uno de tipo std:: decay_t < ValueType > construido a partir de los argumentos.

Primero destruye el objeto contenido actual (si existe) mediante reset() , luego:

1) construye un objeto de tipo std:: decay_t < ValueType > , inicializado-directo-no-lista desde std:: forward < Args > ( args ) ... , como el objeto contenido.
2) construye un objeto de tipo std:: decay_t < ValueType > , inicializado-directo-no-por-lista desde il, std:: forward < Args > ( args ) ... , como el objeto contenido.

Contenidos

Parámetros de plantilla

ValueType - tipo de valor contenido
Requisitos de tipo
-
std::decay_t<ValueType> debe cumplir con los requisitos de CopyConstructible .

Valor de retorno

Una referencia al nuevo objeto contenido.

Excepciones

Lanza cualquier excepción lanzada por T 's constructor. Si se lanza una excepción, el objeto previamente contenido (si existe) ha sido destruido, y * this no contiene un valor.

Ejemplo

#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';
}

Salida posible:

Star::Star(string, int)
Star{"Procyon" : 2943};
St6vectorIcSaIcEE
C++17

Véase también

construye un objeto any
(función miembro pública)
destruye el objeto contenido
(función miembro pública)