std::front_insert_iterator
來自 cppreference.com
< cpp | 迭代器 (iterator)
定義於標頭檔案 <iterator> |
||
template< class Container > class front_insert_iterator |
(C++17 前) | |
template< class Container > class front_insert_iterator; |
(C++17 起) | |
std::front_insert_iterator
是一個 LegacyOutputIterator,它將元素前置插入到為其構造的容器中。每當迭代器(無論是否解引用)被賦值時,就會呼叫容器的 `push_front()` 成員函式。遞增 `std::front_insert_iterator` 是一個空操作。
目錄 |
[編輯] 成員型別
成員型別 | 定義 | ||||
iterator_category
|
std::output_iterator_tag | ||||
value_type
|
void | ||||
difference_type
|
| ||||
pointer
|
void | ||||
reference
|
void | ||||
container_type
|
Container(容器)
|
成員型別 `iterator_category`、`value_type`、`difference_type`、`pointer` 和 `reference` 需透過繼承自 std::iterator<std::output_iterator_tag, void, void, void, void> 獲得。 |
(C++17 前) |
[編輯] 成員函式
構造一個新的 front_insert_iterator (public 成員函式) | |
將物件插入到關聯的容器中 (public 成員函式) | |
無操作 (public 成員函式) | |
無操作 (public 成員函式) |
[編輯] 成員物件
成員名稱 (Member name) | 定義 |
container (protected) |
型別為 Container* 的指標 |
[編輯] 示例
執行此程式碼
#include <algorithm> #include <deque> #include <iostream> #include <iterator> #include <vector> namespace stb { void println(auto, auto const& d) { std::ranges::copy(d, std::ostream_iterator<int>(std::cout, " ")); std::cout << '\n'; } } int main() { std::vector<int> v{1, 2, 3, 4, 5}; std::deque<int> d; std::copy(v.begin(), v.end(), std::front_insert_iterator<std::deque<int>>(d)); // or std::front_inserter(d) stb::println("{}", d); }
輸出
5 4 3 2 1
[編輯] 參閱
建立從引數推斷型別的 std::front_insert_iterator (函式模板) | |
用於在容器末尾插入的迭代器介面卡 (類模板) | |
用於在容器中插入的迭代器介面卡 (類模板) |