命名空间
变体
操作

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

来自 cppreference.cn
< cpp‎ | 容器‎ | list
 
 
 
 
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) 用范围 [firstlast) 中的元素的副本替换内容。
如果任一参数是指向 *this 的迭代器,则行为未定义。

如果 InputIt 是整型,则此重载具有与重载 (1) 相同的效果。

(C++11 前)

仅当 InputIt 满足 LegacyInputIterator 时,此重载才参与重载解析。

(C++11 起)
3) 用来自 ilist 的元素替换内容。

所有指向容器元素的迭代器、指针和引用都将失效。

内容

[编辑] 参数

count - 容器的新大小
value - 用于初始化容器元素的值
first, last - 定义要复制的元素源范围的迭代器对
ilist - std::initializer_list 要从中复制值的

[编辑] 复杂度

1) 线性于 count。
2) 线性于 first 和 last 之间的距离。
3) 线性于 ilist.size()。

[编辑] 示例

以下代码使用 assignstd::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 替换操作曾被要求实现为
先擦除所有现有元素,然后插入给定的元素
移除
要求

[编辑] 参见

向容器赋值一个值范围
(公开成员函数) [编辑]
向容器赋值
(公开成员函数) [编辑]