std::vector::push_back

来自cppreference.com
< cpp‎ | container‎ | vector
void push_back( const T& value );
(1)
void push_back( T&& value );
(2) (C++11 起)

后附给定元素 value 到容器尾。

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

若新的 size() 大于 capacity() ,则所有迭代器和引用(包含尾后迭代器)都被非法化。否则仅尾后迭代器被非法化。

目录

[编辑] 参数

value - 要后附的元素值
类型要求
-
为使用重载 (1) , T 必须满足 CopyInsertable 的要求。
-
为使用重载 (2) , T 必须满足 MoveInsertable 的要求。

[编辑] 返回值

(无)

[编辑] 复杂度

均摊常数。

[编辑] 异常

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

T 的移动构造函数不是 noexcept 且 T 不可复制插入 (CopyInsertable) 到 *this ,则 vector 将使用会抛出的移动构造函数。若它抛出,则抛弃保证且效果未指定。 (C++11 起)

注意

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

[编辑] 示例

#include <vector>
#include <iostream>
#include <iomanip>
 
int main()
{
    std::vector<std::string> numbers;
 
    numbers.push_back("abc");
    std::string s = "def";
    numbers.push_back(std::move(s));
 
    std::cout << "vector holds: ";
    for (auto&& i : numbers) std::cout << std::quoted(i) << ' ';
    std::cout << "\nMoved-from string holds " << std::quoted(s) << '\n';
}

输出:

vector holds: "abc" "def" 
Moved-from string holds ""

[编辑] 参阅

在容器末尾就地构造元素
(公开成员函数) [编辑]
移除末元素
(公开成员函数) [编辑]