std::front_insert_iterator

来自cppreference.com
< cpp‎ | iterator
 
 
迭代器库
迭代器概念
迭代器原语
算法概念与工具
间接可调用概念
常用算法要求
(C++20)
(C++20)
(C++20)
工具
(C++20)
迭代器适配器
范围访问
(C++11)(C++14)
(C++14)(C++14)  
(C++11)(C++14)
(C++14)(C++14)  
(C++17)(C++20)
(C++17)
(C++17)
 
 
在标头 <iterator> 定义
template<class Container >

class front_insert_iterator

    :publicstd::iterator<std::output_iterator_tag, void, void, void, void>
(C++17 前)
template<class Container >
class front_insert_iterator;
(C++17 起)

std::front_insert_iterator 是一种输出迭代器,它向为之构造的容器前附元素。每当赋值给(无论是否解引用)迭代器时就调用容器的 push_front() 成员函数。自增 std::front_insert_iterator 是无操作。

目录

[编辑]成员类型

成员类型 定义
iterator_categorystd::output_iterator_tag
value_typevoid
difference_type

void

(C++20 前)

std::ptrdiff_t

(C++20 起)
pointervoid
referencevoid
container_typeContainer

要求通过从 std::iterator<std::output_iterator_tag, void, void, void, void> 继承获得成员类型 iterator_categoryvalue_typedifference_typepointerreference

(C++17 前)

[编辑]成员函数

构造新的 front_insert_iterator
(公开成员函数)[编辑]
插入对象到关联的容器
(公开成员函数)[编辑]
无操作
(公开成员函数)[编辑]
无操作
(公开成员函数)[编辑]

[编辑]成员对象

成员名 定义
container(受保护)Container* 类型的指针

[编辑]示例

#include <algorithm>#include <deque>#include <iostream>#include <iterator>#include <vector>   namespace stb {void println(auto, autoconst& 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));// 或用 std::front_inserter(d)   stb::println("{}", d);}

输出:

5 4 3 2 1

[编辑]参阅

创建拥有从实参推出的类型的 std::front_insert_iterator
(函数模板)[编辑]
在容器尾部插入的迭代器适配器
(类模板)[编辑]
插入到容器的迭代器适配器
(类模板)[编辑]
close