Namespaces
Variants

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

From cppreference.net

template < class ... Args >
void emplace_back ( Args && ... args ) ;
(до C++17)
template < class ... Args >
reference emplace_back ( Args && ... args ) ;
(начиная с C++17)
(constexpr начиная с C++20)

Добавляет новый элемент в конец контейнера. Элемент создаётся через std::allocator_traits::construct , который обычно использует размещающий new для создания элемента на месте в расположении, предоставленном контейнером. Аргументы args... передаются в конструктор как std:: forward < Args > ( args ) ... .

Если после операции новый size() превышает старый capacity() , происходит перераспределение памяти, в этом случае все итераторы (включая итератор end() ) и все ссылки на элементы становятся недействительными. В противном случае недействительным становится только итератор end() .

Содержание

Параметры

args - аргументы для передачи конструктору элемента
Требования к типу
-
Если выполняется любое из следующих условий, поведение не определено:

Возвращаемое значение

(нет)

(until C++17)

Ссылка на вставленный элемент.

(since C++17)

Сложность

Амортизированная константа.

Исключения

Если исключение выбрасывается по любой причине, данная функция не имеет эффекта ( гарантия строгой безопасности исключений ). Если конструктор перемещения T не является noexcept и не является CopyInsertable в * this , vector будет использовать выбрасывающий конструктор перемещения. Если он выбрасывает исключение, гарантия аннулируется и эффекты не определены.

Примечания

Поскольку может произойти перераспределение памяти, emplace_back требует, чтобы тип элемента был MoveInsertable для vector .

Пример

Следующий код использует emplace_back для добавления объекта типа President в std::vector . Он демонстрирует, как emplace_back передает параметры в конструктор President и показывает, как использование emplace_back позволяет избежать дополнительной операции копирования или перемещения, необходимой при использовании push_back .

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

Вывод:

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.

Смотрите также

добавляет элемент в конец
(public member function)
(C++11)
создаёт элемент на месте
(public member function)