std::front_insert_iterator
来自 cppreference.cn
< 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 (函数模板) | |
| 用于在容器末尾插入的迭代器适配器 (类模板) | |
| 用于在容器中插入的迭代器适配器 (类模板) |