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

来自cppreference.com
< cpp‎ | container‎ | vector

 
 
 
 
void push_back( const T& value );
(1) (C++20 起为 constexpr)
void push_back( T&& value );
(2) (C++11 起)
(C++20 起为 constexpr)

追加给定元素 value 到容器尾。

1) 初始化新元素为 value 的副本。
2) 移动 value 进新元素。

如果操作后新的 size() 大于原 capacity() 则会发生重分配,这种情况下,指代元素的所有迭代器(包括 end() 迭代器)和所有引用均会失效。否则仅有 end() 迭代器失效。

参数

value - 要追加的元素值
类型要求
-
为使用重载 (1), T 必须满足可复制插入 (CopyInsertable)
-
为使用重载 (2), T 必须满足可移动插入 (MoveInsertable)

返回值

(无)

复杂度

均摊常数。

异常

若抛出异常(可能因为 Allocator::allocate() 或元素复制/移动构造函数/赋值),则此函数无效果(强异常保证)。

T 的移动构造函数不是 noexceptT可复制插入 (CopyInsertable) *this,则 vector 将使用会抛出的移动构造函数。若它抛出,则豁免此保证且效果未指定。

(C++11 起)

注解

一些实现在 push_back 导致会超出 max_size 的重分配时亦抛出 std::length_error,这是由于这会隐式调用 reserve(size() + 1) 的等价者。

示例

#include <iomanip>
#include <iostream>
#include <string>
#include <vector>
 
int main()
{
    std::vector<std::string> letters;
 
    letters.push_back("abc");
    std::string s{"def"};
    letters.push_back(std::move(s));
 
    std::cout << "std::vector letters 保有: ";
    for (auto&& e : letters)
        std::cout << std::quoted(e) << ' ';
 
    std::cout << "\n被移动的 string s 保有: " << std::quoted(s) << '\n';
}

可能的输出:

std::vector letters 保有: "abc" "def"
被移动的 string s 保有: ""

参阅

在容器末尾原位构造元素
(公开成员函数)
移除末元素
(公开成员函数)
创建拥有从实参推出的类型的 std::back_insert_iterator
(函数模板)