【STL】迭代器iterator详解

在这里插入图片描述

💐 🌸 🌷 🍀 🌹 🌻 🌺 🍁 🍃 🍂 🌿 🍄🍝 🍛 🍤
📃个人主页 阿然成长日记 👈点击可跳转
📆 个人专栏: 🔹数据结构与算法🔹C语言进阶🔹C++🔹Liunx
🚩 不能则学,不知则问,耻于问人,决无长进
🍭 🍯 🍎 🍏 🍊 🍋 🍒 🍇 🍉 🍓 🍑 🍈 🍌 🍐 🍍

前言

本篇文章以对string的操作来演示迭代器的操作。

一、什么是迭代器iterator?

  • 迭代器(iterator)是一种可以遍历容器元素的数据类型。迭代器是一个变量,相当于容器和操纵容器的算法之间的中介。
  • C++迭代器是一种用于遍历容器中元的对象。它提供了一种统一的访问容器元素的方式,无论容器的类型如何,都可以使用相同的语法进行操作。

二、为什么要使用迭代器?

因为C++更趋向于使用迭代器而不是数组下标操作,因为标准库为每一种标准容器(如vector、map和list等)定义了一种迭代器类型,而只有少数容器(如vector)支持数组下标操作访问容器元素。可以通过迭代器指向你想访问容器的元素地址,通过解引用拿到元素值。这和我们所熟知的指针极其类似。

三、迭代器到底是什么?

  • 迭代器的本质是一个指针,它指向容器中的某个元素。通过迭代器,我们可以访问容器中的元素,并且可以对元素进行修改、删除或插入操作。迭代器可以分为正向迭代器和反向迭代器,分别用于从容器的起始位置向后遍历和从容器的末尾位置向前遍历。

  • 迭代器的实现方式取决于容器的类型。对于数组和指针类型的容器,迭代器本质上就是指针,通过指针的加减运算来实现遍历。对于其他类型的容器,如vector、list等,迭代器是一个包含指向容器元素的指针以及一些操作函数的对象。

  • 总结来说,C++迭代器的本质是一个指针,它提供了一种统一的访问容器元素的方式,使得我们可以方便地遍历和操作容器中的元素。iterator提供一种统一的方式访问和修改容器。

四 、接口汇总

接口作用
begin将迭代器返回到开头
end返回迭代器以结束
rbegin返回反向迭代器以反向开始
rend将反向迭代器返回到反向端
cbegin返回const_iterator开头
cend返回const_iterator结束
crbegin返回const_reverse_iterator以反转开始
crend返回const_reverse_iterator反转端

(1)begin和end
同样有两个重载,一个是普通对象,一个则是const对象

  • begin:获取一个字符的迭代器
  • end:获取最后一个字符下一个位置的迭代器

在这里插入图片描述

实例操作:

string::iterator it = s1.begin();

在这里插入图片描述

  • 每个容器(ist,vector,map等等)里都有iterator迭代器,所以我们要在iterator前加上作用域(当然也可以加auto去自动匹配类型)。
  • it取到的是每个元素的位置,那么对于*it来说即为每个元素。
  • 使用正向迭代器接收iterator.还会有反向迭代器,马上会讲。

💤中途休息~问题思考
那么,如果使用const对象呢?

  • 使用const修饰的迭代器接收:
    在这里插入图片描述

  • 传入const修饰的对象的引用
    在这里插入图片描述

通过上图可以发现,const修饰后,都不能进行修改指向的元素值。

  • 还有重要的一点,在一个函数中,通常使用迭代器遍历封装为函数,采取引用传值减少拷贝构造,再加上const做修饰,防止权限放大。还必须使用const_iterator 接收,如下图👇:

在这里插入图片描述

  • 正确的做法是使用const_iterator 接收👇在这里插入图片描述

(2)rbegin和rend

  • rbegin:指向的是最后一个字符的位置
  • rend: 指向的是第一个字符的前一个位置
    在这里插入图片描述

实例操作:使用反向迭代器接收reverse_iterator
在这里插入图片描述

小结:
四种迭代器:
在这里插入图片描述

可读不可改const_iterator 和 const_reverse_iterator
可读可改iterator 和 reverse_iterator

🚩一定一定注意权限问题!!!

面试题:

为什么这里的while中不写成,最常见的<形式。而要写成!=呢?

在这里插入图片描述

原因:

  • it是一个指针,它指向的当前指向元素的地址。如果是vctor,string这种他们的地址是连在一起的倒是没啥问题。但是,如果是map,set这种的随机地址存储的,这样写肯定是不行的,因为地址不连续,也就没有什么大小可比性了。
  • 20
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
迭代器iterator)是C++ STL(标准模板库)中的一个重要概念,是一个抽象的对象,通过迭代器可以实现对容器(如vector、list、set、map等)中元素的访问。迭代器提供了一种通用的方法,可以将容器的具体实现与使用它的算法分离开来。 迭代器C++容器的基础,它是一种类似于指针的对象,用于指示容器中的元素位置。对于不同类型的容器,有不同类型的迭代器。例如,对于vector容器,可以使用随机访问迭代器(random access iterator),而对于list容器,则需要使用双向迭代器(bidirectional iterator)。 STL中定义了五种不同类型的迭代器,分别是: 1.输入迭代器(Input Iterator):可以通过迭代器读取容器中的元素,但不能修改元素。 2.输出迭代器(Output Iterator):可以通过迭代器向容器中插入新的元素,但不能访问容器中已有的元素。 3.前向迭代器(Forward Iterator):可以访问容器中的元素,并可在容器中向前移动迭代器,但只能遍历容器一次。 4.双向迭代器(Bidirectional Iterator):可以访问容器中的元素,并可在容器中向前或向后移动迭代器,遍历容器的时间复杂度为O(n)。 5.随机访问迭代器(Random Access Iterator):可以访问容器中的元素,并可在容器中随意移动迭代器,可实现常数时间内的随机访问。 迭代器STL中的用处是极大的,通过迭代器,我们可以像操作数组一样高效地操作容器中的元素。熟练掌握迭代器的使用,是C++程序员必备的技能之一。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿然成长日记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值