当前位置: 首页 > news >正文

STL之迭代器(iterator)

迭代器的基本概念

迭代器(iterator)模式又称为游标(Cursor)模式,用于提供一种方法顺序访问一个聚合对象中各个元素, 而又不需暴露该对象的内部表示。或者这样说可能更容易理解:Iterator模式是运用于聚合对象的一种模式,通过运用该模式,使得我们可以在不知道对象内部表示的情况下,按照一定顺序(由iterator提供的方法)访问聚合对象中的各个元素。

迭代器产生原因(或者本质)

Iterator 类的访问方式就是把不同集合类的访问逻辑抽象出来,使得不用暴露集合内部的结构而达到循环遍历集合的效果。

迭代器的类型

输入迭代器 ( InputIterator ) 、输出迭代器 ( OutputIterator ) 、前向迭代器(ForwardIterator ) 、双向迭代器 ( BidirectionalIterator ) 、随机访问迭代器(RandomAccessIterator )
每个迭代器类型对应的操作。

类别
简写
输出
output
输入
input
前向
Forward
双向
Bidirection
随机
Random
=* p
=*p=*p=*p
访问
->
->
->
-> []
* p =
*p=*p=*p=
迭代
++
++++
++/--
++/--/+/-/+=/-=
比较
==/!=
==/!=
==/!=
==/!=/</>/<=/>=
五种迭代器之间的关系图

为什么定义这么多迭代器

物尽其用,使得具体的操作使用具体类型的迭代器,避免迭代器的功能太大或者太小,导致使用起来不方便。每个容器及其对应的迭代器的类型图表如下:
容器
类内迭代器类别
vector
随机访问迭代器
deque
随机访问迭代器
list
双向迭代器
set
双向迭代器
multiset
双向迭代器
map
双向迭代器
multimap
双向迭代器
unordered_set
前向迭代器
unordered_multiset
前向迭代器
unordered_map
前向迭代器
unordered_multimap
前向迭代器

流迭代器

流迭代器是特殊的迭代器,可以将输入 / 输出流作为 容器 看待 ( 因为输入输出都有 缓冲 的概念 ) 。因此,任何接受迭代器参数的算法都可以和流一起工作。关于流迭代器的模板形式:
#include <iterator>
template< class T,
        class CharT = char,
        class Traits = std::char_traits<CharT>,
        class Distance = std::ptrdiff_t
        > class istream_iterator
: public std::iterator<std::input_iterator_tag, T, Distance, const T*, const T&>;


template< class T,
        class CharT = char,
        class Traits = std::char_traits<CharT>,
        class Distance = std::ptrdiff_t
        > class istream_iterator;


template< class T,
        class CharT = char,
        class Traits = std::char_traits<CharT>
        > class ostream_iterator
: public std::iterator<std::output_iterator_tag, void, void, void, void>;


template< class T,
        class CharT = char,
        class Traits = std::char_traits<CharT>
        > class ostream_iterator;
以及两种流迭代器的构造函数
//输出流迭代器的构造函数
ostream_iterator(ostream_type& stream, const CharT* delim);
ostream_iterator(ostream_type& stream);


//输入流迭代器的构造函数
constexpr istream_iterator();
istream_iterator( istream_type& stream );
istream_iterator( const istream_iterator& other ) = default;
输入输出流迭代器的使用示例:
void test()
{
    vector<int> numbers{1, 2, 3, 4, 5};

    ostream_iterator<int> osi(cout, "\n");
    copy(numbers.begin(), numbers.end(), osi);
}

void test()
{
    vector<int> numbers;
    istream_iterator<int> isi(cin);

    //对于vector插入元素应该调用push_back
    //copy(isi, istream_iterator<int>(), numbers.begin());//这样写会有bug,可以思考一下什么原因
    copy(isi, istream_iterator<int>(), std::back_inserter(numbers));
    copy(numbers.begin(), numbers.end(), ostream_iterator<int>(cout, "\n"));
}

迭代器适配器

back _ inserter 是函数模板,该函数模板的返回类型是类模板 back _ insert _ iterator ,而类模板back  _ i nsert _ iterator 底层调用了 push _ back 函数;
front _ inserter 是函数模板,该函数模板的返回类型是类模板 front insert iterator ,而类模板fron t  _ insert  iterator 底层调用了 push _ front 函数;
inserter 是函数模板,函数模板的返回类型是类模板 insert _ iterator ,而类模板insert_ iterator 底层调用了 insert 函数。
下面是三个函数模板的接口原型:
template< class Container >
std::back_insert_iterator<Container> back_inserter( Container& c );

template< class Container >
std::front_insert_iterator<Container> front_inserter( Container& c );

template< class Container >
std::insert_iterator<Container>
inserter( Container& c, typename Container::iterator i );
三者对应的可能实现如下:
template< class Container >
std::back_insert_iterator<Container> back_inserter( Container& c )
{
    return std::back_insert_iterator<Container>(c);
}

template< class Container >
std::front_insert_iterator<Container> front_inserter( Container& c )
{
    return std::front_insert_iterator<Container>(c);
}

template< class Container >
std::insert_iterator<Container>
inserter( Container& c, typename Container::iterator i )
{
    return std::insert_iterator<Container>(c, i);
}

相关文章:

  • case客户续保预测中用到的特征工程、回归分析和决策树分析的总结
  • 监控相关信息 - 留档备查
  • 计算机体系结构之指令体系结构
  • Ubuntu虚拟机Linux系统入门
  • 从能量守恒的角度理解自然现象与社会现象
  • 【C语言】结构体 (深入)
  • python | tracemalloc模块,跟踪内存分配情况
  • 【时时三省】(C语言基础)选择结构程序综合举例2
  • 浅淡红黑树以及其在Java中的实际应用
  • 【ACM MM会议-2024工业异常检测】FiLo++:融合细粒度描述和形变定位的零样本/少样本异常检测
  • IO多路复用沉浸式体验
  • OpenAI Gym 提供了丰富的强化学习测试环境
  • 并发阻塞队列原理分析
  • 用户自定义函数(UDF)开发与应用(二)
  • 快速幂运算
  • 阅读论文 smart pretrain,搭配MAE一起食用
  • Elasticsearch 性能优化:从原理到实践的全面指南
  • Elasticsearch入门指南(三) 之 高级篇
  • 2025蓝桥杯JavaB组真题解析
  • JavaScript性能优化(下)
  • 七旬男子驾“老头乐”酒驾被查,曾有两次酒驾两次肇事记录
  • 国务院关税税则委:调整对原产于美国的进口商品加征关税措施
  • “一码难求”的Manus开放注册但价格不菲,智能体距离“实用”还有多远
  • 马上评丨未成年人“擦边”短视频岂能成流量密码
  • 听企业聊感受,《外企聊营商》5月13日起推出
  • 做街坊们的“健康管家”,她把专科护理服务送上门