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

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

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

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

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

没有引用和迭代器被非法化。

参数

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

返回值

(无)

复杂度

常数。

异常

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


示例

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

输出:

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

参阅

在容器末尾就地构造元素
(公开成员函数)
插入元素到容器起始
(公开成员函数)
移除末元素
(公开成员函数)