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 底层依赖迭代器
相关推荐
Highcharts.js2 小时前
缺失数据可视化图表开发实战|Highcharts创建人员出生统计面积图表示例
开发语言·前端·javascript·信息可视化·highcharts·图表开发
测试员周周7 小时前
【Appium 系列】第16节-WebView-H5上下文切换 — 混合应用的自动化难点
运维·开发语言·人工智能·功能测试·appium·自动化·测试用例
杜子不疼.9 小时前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
加号310 小时前
【C#】 串口通信技术深度解析及实现
开发语言·c#
sycmancia10 小时前
Qt——编辑交互功能的实现
开发语言·qt
石山代码11 小时前
C++ 内存分区 堆区
java·开发语言·c++
无风听海11 小时前
C# 隐式转换深度解析
java·开发语言·c#
一只大袋鼠12 小时前
Git 进阶(二):分支管理、暂存栈、远程仓库与多人协作
java·开发语言·git
LuminousCPP12 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习
web3.088899912 小时前
1688 图搜接口(item_search_img / 拍立淘) 接入方法
开发语言·python