Namensräume
Varianten
Aktionen

std::list<T,Allocator>::emplace_back

Von cppreference.com
< cpp‎ | container‎ | list
 
 
 
 
template< class... Args >
void emplace_back( Args&&... args );
(seit C++11)
(bis C++17)
template< class... Args >
reference emplace_back( Args&&... args );
(seit C++17)

Hängt ein neues Element am Ende des Containers an. Das Element wird über std::allocator_traits::construct konstruiert, welches typischerweise Placement-new verwendet, um das Element an der vom Container bereitgestellten Stelle direkt zu konstruieren. Die Argumente args... werden als std::forward<Args>(args)... an den Konstruktor weitergeleitet.

Keine Iteratoren oder Referenzen werden ungültig.

Inhalt

[bearbeiten] Parameter

args - Argumente, die an den Konstruktor des Elements weitergeleitet werden
Typanforderungen
-
T (der Elementtyp des Containers) muss die Anforderungen an EmplaceConstructible erfüllen.

[bearbeiten] Rückgabewert

(keine)

(bis C++17)

Eine Referenz auf das eingefügte Element.

(seit C++17)

[bearbeiten] Komplexität

Konstant.

[bearbeiten] Ausnahmen

Wenn aus irgendeinem Grund eine Ausnahme ausgelöst wird, hat diese Funktion keine Auswirkungen (starkes Ausnahmesicherheitsgarantie).


[bearbeiten] Beispiel

Der folgende Code verwendet emplace_back, um ein Objekt vom Typ President an eine std::list anzuhängen. Er demonstriert, wie emplace_back Parameter an den President-Konstruktor weiterleitet und zeigt, wie die Verwendung von emplace_back die zusätzliche Kopier- oder Verschiebeoperation vermeidet, die bei der Verwendung von push_back erforderlich ist.

#include <list>
#include <cassert>
#include <iostream>
#include <string>
 
struct President
{
    std::string name;
    std::string country;
    int year;
 
    President(std::string p_name, std::string p_country, int p_year)
        : name(std::move(p_name)), country(std::move(p_country)), year(p_year)
    {
        std::cout << "I am being constructed.\n";
    }
 
    President(President&& other)
        : name(std::move(other.name)), country(std::move(other.country)), year(other.year)
    {
        std::cout << "I am being moved.\n";
    }
 
    President& operator=(const President& other) = default;
};
 
int main()
{
    std::list<President> elections;
    std::cout << "emplace_back:\n";
    auto& ref = elections.emplace_back("Nelson Mandela", "South Africa", 1994);
    assert(ref.year == 1994 && "uses a reference to the created object (C++17)");
 
    std::list<President> reElections;
    std::cout << "\npush_back:\n";
    reElections.push_back(President("Franklin Delano Roosevelt", "the USA", 1936));
 
    std::cout << "\nContents:\n";
    for (President const& president: elections)
        std::cout << president.name << " was elected president of "
                  << president.country << " in " << president.year << ".\n";
 
    for (President const& president: reElections)
        std::cout << president.name << " was re-elected president of "
                  << president.country << " in " << president.year << ".\n";
}

Ausgabe

emplace_back:
I am being constructed.
 
push_back:
I am being constructed.
I am being moved.
 
Contents:
Nelson Mandela was elected president of South Africa in 1994.
Franklin Delano Roosevelt was re-elected president of the USA in 1936.

[bearbeiten] Siehe auch

fügt ein Element am Ende hinzu
(public member function) [edit]
(C++11)
konstruiert Elemente direkt (in-place)
(public member function) [edit]