STL迭代器:容器遍历的万能钥匙

一、什么是迭代器

迭代器本质:容器的通用智能指针作用:

  1. 统一所有容器遍历方式
  2. 不用关心底层是数组、链表、哈希表
  3. 配合 STL 算法直接使用

通俗理解:指针只能访问内存;迭代器可以遍历任意 STL 容器

二、迭代器基础语法

定义格式:

复制代码
容器类型::iterator 迭代器名;

示例:vector 迭代器

复制代码
#include <iostream>
#include <vector>
using namespace std;

int main()
{
    vector<int> v = {10,20,30,40};

    // 定义迭代器
    vector<int>::iterator it;

    // begin() 指向第一个元素
    // end() 指向最后一个元素的下一个位置
    for(it = v.begin(); it != v.end(); it++)
    {
        cout << *it << " ";
    }
    return 0;
}

输出:

复制代码
10 20 30 40

三、迭代器核心端点

  • begin():返回首元素迭代器
  • end():返回末尾后一位迭代器 ,不代表有效元素遍历判断标准:it != v.end() 不要用 <=

四、迭代器四种分类

  1. 普通迭代器 iterator可读可写,可修改容器元素

    vector<int>::iterator it;
    *it = 100;

  2. 常量迭代器 const_iterator只能读、不能修改,保护数据

    vector<int>::const_iterator it;
    // *it = 100; 报错

  3. 反向迭代器 reverse_iterator从后往前遍历

cpp

运行

复制代码
vector<int>::reverse_iterator it;
for(it = v.rbegin(); it != v.rend(); ++it)
{
    cout << *it << " ";
}
  1. 只读反向迭代器遍历只读、逆序,日常用得少。

五、迭代器常用操作

复制代码
it++    // 往后移动一位
it--    // 往前移动一位
*it     // 取迭代器指向元素
it->    // 访问结构体/类对象成员

六、string 也能用迭代器

string 本质也是容器,同样支持:

复制代码
string s = "hello";
for(string::iterator it = s.begin(); it != s.end(); ++it)
{
    cout << *it;
}

七、C++11 范围 for 底层原理

复制代码
for(int x : v)
{
    cout << x;
}

底层本质就是迭代器遍历,只是语法简化。

八、新手易错点

  1. end() 当成最后一个有效元素
  2. 迭代器遍历中随意增删元素,导致迭代器失效
  3. const 迭代器试图修改元素
  4. 逆序迭代器分不清 rbegin /rend

九、今日总结

  1. 迭代器是 STL 通用遍历标准,相当于容器专用指针
  2. 核心成员:begin() 首位置、end() 尾后位置
  3. 常用四种:普通、常量、反向、常量反向
  4. 所有 STL 容器都支持迭代器,学会一个通吃所有
  5. 范围 for 底层依赖迭代器
相关推荐
azoo1 小时前
emplace_back和push_back() 函数添加 cv::Point 类型数据
c++·opencv
样例过了就是过了2 小时前
LeetCode热题 不同路径
c++·算法·leetcode·动态规划
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题】【Java基础篇】第24题:Java面向对象有哪些特征
java·开发语言·后端·面试
geovindu2 小时前
go: Strategy Pattern
开发语言·设计模式·golang·策略模式
27669582922 小时前
阿里最新acw_sc__v2 分析
开发语言·python·acw_sc__v2·acw_sc__v2逆向·acw_sc__v2算法·acw_sc__v2算法分析·cookie逆向
dog2502 小时前
圆锥曲线和二次曲线
开发语言·网络·人工智能·算法·php
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题】【Java基础篇】第25题:JDK1.8的新特性有哪些
java·开发语言·后端·面试
开发小程序的之朴2 小时前
基于Go语言的企业级CMS系统架构设计与性能分析——以AnQiCMS为例
开发语言·golang·系统架构