std::insert_iterator
来自cppreference.com
<tbody>
</tbody>
<tbody class="t-dcl-rev ">
</tbody><tbody>
</tbody>
| 在标头 <iterator> 定义
|
||
template< class Container > class insert_iterator : public std::iterator<std::output_iterator_tag, void, void, void, void> |
(C++17 前) | |
template< class Container > class insert_iterator; |
(C++17 起) | |
std::insert_iterator 是一种老式输出迭代器 (LegacyOutputIterator) ,在所提供的迭代器所指向的位置,向为之构造的容器插入元素。每当赋值给迭代器时(无论是否解引用),就调用容器的 insert() 成员函数。自增 std::insert_iterator 是无操作。
成员类型
| 成员类型 | 定义 | ||||
iterator_category
|
std::output_iterator_tag
| ||||
value_type
|
void
| ||||
difference_type
|
| ||||
pointer
|
void
| ||||
reference
|
void
| ||||
container_type
|
Container
|
|
要求通过从 |
(C++17 前) |
成员函数
构造新的 insert_iterator (公开成员函数) | |
| 插入对象到关联的容器 (公开成员函数) | |
| 无操作 (公开成员函数) | |
| 无操作 (公开成员函数) |
成员对象
| 成员名 | 定义 |
container (受保护成员对象)
|
Container* 类型的指针
|
iter (受保护成员对象)
|
Container::iterator(C++20 前)ranges::iterator_t<Container>(C++20 起) 类型的迭代器
|
示例
运行此代码
#include <algorithm>
#include <iostream>
#include <iterator>
#include <list>
#include <vector>
int main()
{
std::vector<int> v{1, 2, 3, 4, 5};
std::list<int> l{-1, -2, -3};
std::copy(v.begin(), v.end(), // 可用 std::inserter 简化
std::insert_iterator<std::list<int>>(l, std::next(l.begin())));
for (int n : l)
std::cout << n << ' ';
std::cout << '\n';
}
输出:
-1 1 2 3 4 5 -2 -3
参阅
| 创建拥有从实参推出的类型的 std::insert_iterator (函数模板) | |
| 在容器尾部插入的迭代器适配器 (类模板) | |
| 在容器头部插入的迭代器适配器 (类模板) |