std::list<T,Allocator>::assign
来自 cppreference.cn
void assign( size_type count, const T& value ); |
(1) | |
template< class InputIt > void assign( InputIt first, InputIt last ); |
(2) | |
void assign( std::initializer_list<T> ilist ); |
(3) | (C++11 起) |
替换容器的内容。
1) 用 value 的 count 份副本替换内容。
2) 用范围
[
first,
last)
中的元素的副本替换内容。 如果任一参数是指向 *this 的迭代器,则行为未定义。
如果 |
(C++11 前) |
仅当 |
(C++11 起) |
3) 用来自 ilist 的元素替换内容。
所有指向容器元素的迭代器、指针和引用都将失效。
内容 |
[编辑] 参数
count | - | 容器的新大小 |
value | - | 用于初始化容器元素的值 |
first, last | - | 定义要复制的元素源范围的迭代器对 |
ilist | - | std::initializer_list 要从中复制值的 |
[编辑] 复杂度
1) 线性于 count。
2) 线性于 first 和 last 之间的距离。
3) 线性于 ilist.size()。
[编辑] 示例
以下代码使用 assign
向 std::list<char> 添加若干字符
运行此代码
#include <list> #include <iostream> #include <string> int main() { std::list<char> characters; auto print_list = [&]() { for (char c : characters) std::cout << c << ' '; std::cout << '\n'; }; characters.assign(5, 'a'); print_list(); const std::string extra(6, 'b'); characters.assign(extra.begin(), extra.end()); print_list(); characters.assign({'C', '+', '+', '1', '1'}); print_list(); }
输出
a a a a a b b b b b b C + + 1 1
缺陷报告
以下行为变更缺陷报告被追溯应用于先前发布的 C++ 标准。
DR | 应用于 | 已发布行为 | 正确行为 |
---|---|---|---|
LWG 320 | C++98 | 替换操作曾被要求实现为 先擦除所有现有元素,然后插入给定的元素 |
移除 要求 |
[编辑] 参见
(C++23) |
向容器赋值一个值范围 (公开成员函数) |
向容器赋值 (公开成员函数) |