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

来自cppreference.com
< cpp‎ | container‎ | 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)countvalue 的副本替换内容。
2) 以范围 [first, last) 中元素的副本替换内容。其中有任何一个迭代器是指向 *this 中的迭代器时行为未定义。

如果 InputIt 是整数类型,那么此重载与 (1) 拥有相同效果。

(C++11 前)

此重载只有在InputIt 满足老式输入迭代器 (LegacyInputIterator) 时才会参与重载决议。

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

所有指向容器元素的迭代器、指针及引用均被非法化。

参数

count - 容器的新大小
value - 用以初始化容器元素的值
first, last - 复制来源元素的范围
ilist - 复制值来源的 initializer_list

复杂度

1)count 呈线性
2)firstlast 间的距离呈线性
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++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 320 C++98 替换操作定义为在移除所有既存元素后插入指定的元素 移除该定义

参阅

构造 list
(公开成员函数)