std::forward_list<T,Allocator>::assign
來自 cppreference.com
< cpp | 容器 | forward_list
void assign( size_type count, const T& value ); |
(1) | (C++11 起) |
template< class InputIt > void assign( InputIt first, InputIt last ); |
(2) | (C++11 起) |
void assign( std::initializer_list<T> ilist ); |
(3) | (C++11 起) |
替換容器的內容。
1) 將內容替換為 count 個 value 的副本。
2) 將內容替換為範圍
[
first,
last)
中的副本。 如果任一引數是 *this 的迭代器,則行為是未定義的。
如果 |
(C++11 前) |
此過載僅在 `InputIt` 滿足 LegacyInputIterator 時參與過載決議。 |
(C++11 起) |
3) 將內容替換為 ilist 中的元素。
容器中所有迭代器、指標和元素的引用都將失效。
目錄 |
[編輯] 引數
count | - | 容器的新大小 |
value | - | 用於初始化容器元素的數值 |
first, last | - | 定義要複製的元素的源 範圍 的迭代器對 |
ilist | - | std::initializer_list,從中複製值 |
[編輯] 複雜度
1) 關於 count 的線性複雜度。
2) 關於 first 和 last 之間距離的線性複雜度。
3) 關於 ilist.size() 的線性複雜度。
[編輯] 示例
以下程式碼使用 `assign` 向 std::forward_list<char> 新增多個字元。
執行此程式碼
#include <forward_list> #include <iostream> #include <string> int main() { std::forward_list<char> characters; auto print_forward_list = [&]() { for (char c : characters) std::cout << c << ' '; std::cout << '\n'; }; characters.assign(5, 'a'); print_forward_list(); const std::string extra(6, 'b'); characters.assign(extra.begin(), extra.end()); print_forward_list(); characters.assign({'C', '+', '+', '1', '1'}); print_forward_list(); }
輸出
a a a a a b b b b b b C + + 1 1
缺陷報告
下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。
缺陷報告 | 應用於 | 釋出時的行為 | 正確的行為 |
---|---|---|---|
LWG 2209 | C++11 | 替換操作要求實現為 擦除所有現有元素,然後插入給定元素 |
移除了冗餘要求 要求 |
[編輯] 參閱
(C++23) |
將一個範圍的值賦給容器 (public member function) |
將值賦給容器 (public member function) |