Namespaces
Variants

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

From cppreference.net

template < class ... Args >
void emplace_back ( Args && ... args ) ;
(bis C++17)
template < class ... Args >
reference emplace_back ( Args && ... args ) ;
(seit C++17)
(constexpr seit C++20)

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

Falls nach der Operation die neue size() größer ist als die alte capacity() , findet eine Neuzuweisung statt, bei der alle Iteratoren (einschließlich des end() -Iterators) und alle Referenzen auf die Elemente ungültig werden. Andernfalls wird nur der end() -Iterator ungültig.

Inhaltsverzeichnis

Parameter

args - Argumente, die an den Konstruktor des Elements weitergeleitet werden
Typanforderungen
-
Wenn eine der folgenden Bedingungen erfüllt ist, ist das Verhalten undefiniert:

Rückgabewert

(keine)

(bis C++17)

Eine Referenz auf das eingefügte Element.

(seit C++17)

Komplexität

Amortisiert konstant.

Ausnahmen

Wenn aus irgendeinem Grund eine Exception ausgelöst wird, hat diese Funktion keine Wirkung ( starke Exception-Sicherheitsgarantie ). Wenn der Move-Konstruktor von T nicht noexcept ist und nicht CopyInsertable in * this ist, wird vector den werfenden Move-Konstruktor verwenden. Wenn dieser eine Exception auslöst, ist die Garantie aufgehoben und die Effekte sind nicht spezifiziert.

Hinweise

Da eine Neuzuordnung stattfinden kann, emplace_back erfordert, dass der Elementtyp MoveInsertable für vector ist.

Beispiel

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

#include <vector>
#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::vector<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::vector<President> reElections;
    std::cout << "\npush_back:\n";
    reElections.push_back(President("Franklin Delano Roosevelt", "the USA", 1936));
    std::cout << "\nContents:\n";
    for (const President& president: elections)
        std::cout << president.name << " was elected president of "
                  << president.country << " in " << president.year << ".\n";
    for (const President& 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.

Siehe auch

fügt ein Element am Ende hinzu
(öffentliche Elementfunktion)
(C++11)
konstruiert Element direkt vor Ort
(öffentliche Elementfunktion)