Namespaces
Variants

std::inplace_vector<T,N>:: emplace_back

From cppreference.net
template < class ... Args >
constexpr reference emplace_back ( Args && ... args ) ;
(C++26부터)

컨테이너의 끝에 새로운 요소를 추가합니다. 일반적으로 요소는 컨테이너가 제공한 위치에서 제자리 생성(in-place)하기 위해 배치 new 를 사용하여 생성됩니다. 인수 args... 는 생성자에게 std:: forward < Args > ( args ) ... 로 전달됩니다.

반복자나 참조는 무효화되지 않습니다. 단, end() 는 삽입이 발생할 경우 무효화됩니다.

목차

매개변수

args - 요소의 생성자에 전달할 인수들
타입 요구사항
-
T EmplaceConstructible 요구사항을 충족해야 합니다.

반환값

back() , 즉 삽입된 요소에 대한 참조입니다.

복잡도

상수.

예외

  • std::bad_alloc 이 발생하는 경우: size ( ) == capacity ( ) 가 호출 전에 참인 경우.
  • 삽입된 요소의 초기화 과정에서 발생하는 모든 예외.

어떤 이유로든 예외가 발생하면, 이 함수들은 아무런 효과를 가지지 않습니다( strong exception safety guarantee ).

예제

#include <inplace_vector>
#include <new>
#include <print>
#include <string>
#include <utility>
int main()
{
    std::inplace_vector<std::pair<std::string, std::string>, 2> fauna;
    std::string dog{"\N{DOG}"};
    fauna.emplace_back("\N{CAT}", dog);
    fauna.emplace_back("\N{CAT}", std::move(dog));
    std::println("fauna = {}", fauna);
    try
    {
        fauna.emplace_back("\N{BUG}", "\N{BUG}"); // 예외 발생: 공간이 부족함
    }
    catch(const std::bad_alloc& ex)
    {
        std::println("{}", ex.what());
    }
    std::println("fauna = {}", fauna);
}

가능한 출력:

fauna = [("🐈", "🐕"), ("🐈", "🐕")]
std::bad_alloc
fauna = [("🐈", "🐕"), ("🐈", "🐕")]

참고 항목

끝에 요소들의 범위를 추가함
(public member function)
끝에 요소를 추가함
(public member function)
끝에 요소를 추가하려 시도함
(public member function)
끝에 제자리에서 요소를 생성하려 시도함
(public member function)
끝에 요소들의 범위를 추가하려 시도함
(public member function)
무조건적으로 끝에 요소를 추가함
(public member function)
무조건적으로 끝에 제자리에서 요소를 생성함
(public member function)
마지막 요소를 제거함
(public member function)
인자로부터 추론된 타입의 std::back_insert_iterator 를 생성함
(function template)