【C++】深入理解迭代器(Iterator)


在这里插入图片描述

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳]
本文专栏: C++

文章目录

  • 💯前言
  • 💯什么是迭代器?
    • 迭代器与指针的比较
  • 💯`std::string` 中的迭代器
    • 示例代码与图示分析
      • 运行结果:
      • 图示说明:
    • 小提示
  • 💯正序遍历与逆序遍历
    • 正序遍历
      • 示例代码
      • 运行结果
    • 逆序遍历
      • 示例代码
      • 运行结果
      • 注意
  • 💯修改字符串内容
      • 示例代码
      • 运行结果
    • 解释
  • 💯拓展:迭代器的更多功能
    • 迭代器类型
    • 常用 STL 算法与迭代器
      • 示例:查找特定字符
  • 💯小结


在这里插入图片描述


💯前言

  • C++ 是一门功能强大的编程语言,其标准库(STL, Standard Template Library)提供了多种高效的工具来处理数据。其中,迭代器(Iterator)是一种极为重要的工具,可以帮助开发者优雅地操作容器,遍历、访问和修改数据。迭代器的作用类似于指针,但比指针更强大和灵活。本文将以 std::string 为例,结合代码和图示,从基本概念到实际应用,带领读者深入理解 C++ 中迭代器的核心功能和用法。
    C++ 参考手册
    在这里插入图片描述

💯什么是迭代器?

迭代器(Iterator)是 C++ 标准模板库中的一种对象,专为遍历容器中的元素而设计。它的工作方式类似于指针,但具备更多功能。

迭代器的主要特点包括:

  • 抽象化:通过统一的接口操作不同类型的容器(如 vectorstringlist 等)。
  • 灵活性:支持顺序遍历、逆序遍历,以及访问和修改容器中的元素。
  • 安全性:迭代器相比裸指针更安全,更符合现代 C++ 的编程规范。

在迭代器的使用过程中,特别需要注意访问迭代器指向的值时必须解引用(* 操作符)。

迭代器与指针的比较

迭代器和指针有许多相似之处,例如它们都可以通过递增(++)、递减(--)、解引用(*)来访问和操作数据。但是,迭代器是针对容器设计的,它们具有更强的抽象能力,可以屏蔽容器的底层实现,从而使代码更通用和易维护。

💯std::string 中的迭代器

C++ 中的 std::string 提供了多种迭代器,用于遍历字符串中的字符和修改字符串的内容。下面是我们将重点讨论的两个基本方法:

  • begin():返回指向字符串第一个字符的迭代器。
  • end():返回指向字符串最后一个字符的下一个位置的迭代器。

示例代码与图示分析

让我们通过具体的代码和图示来理解 begin()end() 的用法。

#include <iostream>
#include <string>
using namespace std;

int main() {
    string s = "abcdef";

    string::iterator it1 = s.begin();
    string::iterator it2 = s.end();

    cout << (it1 < it2) << endl;
    cout << it1 - it2 << endl;

    return 0;
}

运行结果:

1
-6

图示说明:

假设字符串 s = "abcdef",其下标和迭代器关系如下:

下标012345-
字符abcdef
迭代器s.begin()s.end()
  • s.begin() 返回指向第一个字符(即 a)的迭代器。
  • s.end() 返回指向超出最后一个字符的迭代器位置(并非 f 的位置,而是 f 后面的位置)。
  • 在输出中:
    • it1 < it2 判断迭代器的位置关系,结果为 true(即 1)。
    • it1 - it2 计算迭代器间的距离,结果为 -6,表示从起点到终点有 6 个字符。

小提示

  • 迭代器支持大小比较(<> 等),也支持加减整数(it + nit - n)。
  • 两个迭代器相减的结果是它们之间的元素个数。
  • 迭代器的灵活操作为字符串的高效遍历和操作提供了保障。

💯正序遍历与逆序遍历

正序遍历

正序遍历是迭代器最常见的应用方式,从字符串的起始位置到结束位置依次访问每个字符。

示例代码

#include <iostream>
#include <string>
using namespace std;

int main() {
    string s = "abcdef";

    // 使用 auto 自动推导迭代器类型
    for (auto it = s.begin(); it != s.end(); ++it) {
        cout << *it << ' ';
    }

    // 或者显式声明迭代器类型
    for (string::iterator it = s.begin(); it != s.end(); ++it) {
        cout << *it << ' ';
    }

    return 0;
}

运行结果

a b c d e f

逆序遍历

逆序遍历则是从字符串的末尾位置开始,逐步向前遍历。

示例代码

#include <iostream>
#include <string>
using namespace std;

int main() {
    string s = "abcdef";

    for (string::iterator it = s.end() - 1; it >= s.begin(); --it) {
        cout << *it << ' ';
    }

    return 0;
}

运行结果

f e d c b a

注意

逆序遍历中,s.end() - 1 指向最后一个字符,而不是 s.end()

💯修改字符串内容

迭代器不仅可以用于遍历,还可以直接修改容器中的内容。

示例代码

#include <iostream>
#include <string>
using namespace std;

int main() {
    string str = "abcdef";

    // 修改前输出原字符串
    cout << str << endl;

    // 使用迭代器修改字符串
    for (string::iterator it = str.begin(); it != str.end(); ++it) {
        *it = 'x'; // 修改每个字符为 'x'
    }

    // 修改后输出新字符串
    cout << str << endl;

    return 0;
}

运行结果

abcdef
xxxxxx

解释

通过迭代器访问字符串中的每个字符,并使用 *it = 'x' 将其修改为 x,实现了对原字符串的就地修改。


💯拓展:迭代器的更多功能

迭代器类型

C++ 提供了多种迭代器,常见的有:

  • 输入迭代器(Input Iterator):只读访问容器中的元素。
  • 输出迭代器(Output Iterator):只写访问容器中的元素。
  • 前向迭代器(Forward Iterator):支持单向遍历。
  • 双向迭代器(Bidirectional Iterator):支持正序和逆序遍历(如 string::iterator)。
  • 随机访问迭代器(Random Access Iterator):支持随机访问容器中的任意元素(如 vector 的迭代器)。

常用 STL 算法与迭代器

C++ STL 提供了大量算法,可以与迭代器配合使用,例如:

  • std::find:查找特定元素。
  • std::sort:排序。
  • std::copy:复制容器内容。

示例:查找特定字符

#include <iostream>
#include <string>
#include <algorithm>
using namespace std;

int main() {
    string s = "abcdef";

    auto it = find(s.begin(), s.end(), 'c');

    if (it != s.end()) {
        cout << "Found: " << *it << endl;
    } else {
        cout << "Not Found" << endl;
    }

    return 0;
}

💯小结

通过本文的详细分析,我们可以看到,迭代器是 C++ STL 中操作容器的核心工具。无论是遍历、修改还是配合算法使用,迭代器都能够提供高效且优雅的解决方案。本文以 std::string 为例,结合代码和图示,讲解了迭代器的基本用法,并拓展了迭代器的更多应用场景。

迭代器的灵活性为开发者带来了极大的便利,但也需要我们在使用时注意边界条件和逻辑错误。如果你对 C++ 中其他容器(如 vectormap 等)感兴趣,迭代器同样适用,甚至更为强大,欢迎进一步探索!


在这里插入图片描述


在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/950442.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

H266/VVC 帧内预测中 MDIS 技术

参考像素平滑滤波 MDIS VVC 的帧内预测参考像素获取过程和 HEVC 相同&#xff0c;但参考像素滤波过程有所改进。在H.266中 MDIS&#xff08;Mode Dependent Intra Smoothing&#xff09;即模式依赖帧内平滑滤波&#xff0c;是对帧内预测的亮度分量参考像素进行滤波决策的一个技…

Chrome访问https页面显示ERR_CERT_INVALID,且无法跳过继续访问

在访问网页的时候&#xff0c;因为浏览器自身的安全设置问题&#xff0c; 对于https的网页访问会出现安全隐私的提示&#xff0c; 甚至无法访问对应的网站&#xff0c;尤其是chrome浏览器&#xff0c; 因此本文主要讲解如何设置chrome浏览器的设置&#xff0c;来解决该问题&…

深入解析 Transformer:从原理到可视化再到PyTorch实现

文章目录 深入解析 Transformer1 理解 Transformer1.1 理解自注意力机制 (Self-Attention)1.2 理解位置编码 (Positional Encoding)1.2.1 整数编码1.2.2 正弦编码 1.3 理解编码器和解码器模块1.3.1 编码器 1.4 最终线性层和 Softmax 层 2 编写 Transformer 的代码2.1 摘要和引言…

系统架构设计师考点—软件工程基础知识

一、备考指南 软件工程基础知识主要考查的是软件工程基础、软件开发方法、系统分析、设计、测试及运行和维护等相关知识&#xff0c;同时也是重点考点&#xff0c;在系统架构设计师的考试中选择题12~15分&#xff0c;案例分析和论文中也会考到相关内容&#xff0c;属于重点章节…

电影动画shader解析与实现

着色器代码解析 大家好&#xff01;我是 [数擎AI]&#xff0c;一位热爱探索新技术的前端开发者&#xff0c;在这里分享前端和Web3D、AI技术的干货与实战经验。如果你对技术有热情&#xff0c;欢迎关注我的文章&#xff0c;我们一起成长、进步&#xff01; 开发领域&#xff1a;…

使用ML.NET进行对象检测

1、前言 ML.NET 是面向 .NET 开发人员的开源跨平台机器学习框架&#xff0c;支持将自定义机器学习模型集成到 .NET 应用程序中。 它包含一个 API&#xff0c;其中包含不同的 NuGet 包、名为 模型生成器的 Visual Studio 扩展&#xff0c;以及作为 .NET 工具安装的 命令行接口。…

年会抽奖Html

在这里插入图片描述 <!-- <video id"backgroundMusic" src"file:///D:/background.mp3" loop autoplay></video> --> <divstyle"width: 290px; height: 580px; margin-left: 20px; margin-top: 20px; background: url(D:/nianhu…

vue -关于浏览器localstorge数据定期清除的实现

1.实现背景 用户登录时的信息存在了localstorge中&#xff0c;但它会一直存在。一般来说&#xff0c;我们希望这个数据能够定期被清除掉&#xff0c;以下一个定时清除的实现。 2.实现原理 在用户登录时&#xff0c;将用户信息存入localstorge的同时&#xff0c;将当前时间作…

LabVIEW水轮发电机组振动摆度故障诊断

本文介绍了基于LabVIEW的水轮发电机组振动摆度故障诊断系统的设计与实施过程。系统在通过高效的故障诊断功能&#xff0c;实现水轮发电机组的振动、温度等关键指标的实时监控与智能分析&#xff0c;从而提高电力设备的可靠性和安全性。 ​ 项目背景 随着电力行业对设备稳定性…

Collaborate with AI -- Write a modern C++ singleton factory

translate my blog <<与AI合作 -- 写一个modern c单例工厂>> to English. NOTE: It was written at 2024.01, maybe the AI is not smart as now. Preface In this article, readers can learn about a hybrid of the modern C singleton pattern and factory pat…

【轻松学C:编程小白的大冒险】--- C语言简介 02

在编程的艺术世界里&#xff0c;代码和灵感需要寻找到最佳的交融点&#xff0c;才能打造出令人为之惊叹的作品。而在这座秋知叶i博客的殿堂里&#xff0c;我们将共同追寻这种完美结合&#xff0c;为未来的世界留下属于我们的独特印记。 【轻松学C&#xff1a;编程小白的大冒险】…

下载b站高清视频

需要使用的edge上的一个扩展插件&#xff0c;所以选择使用edge浏览器。 1、在edge浏览器上下载 强力视频下载合并 扩展插件 2、在edge上打开b站&#xff0c;登录自己账号&#xff08;登录后才能下载到高清&#xff01;&#xff01;&#xff09;。打开一个视频&#xff0c;选择自…

oxml中创建CT_Document类

概述 本文基于python-docx源码&#xff0c;详细记录CT_Document类创建的过程&#xff0c;以此来加深对Python中元类、以及CT_Document元素类的认识。 元类简介 元类&#xff08;MetaClass&#xff09;是Python中的高级特性。元类是什么呢&#xff1f;Python是面向对象编程…

Tableau数据可视化与仪表盘搭建-基础图表制作

目录 对比分析&#xff1a;比大小 柱状图 条形图 数据钻取 筛选器 热力图 气泡图 变化分析&#xff1a;看趋势 折线图 预测 面积图 关系分布&#xff1a;看位置 散点图 直方图 地图 构成分析&#xff1a;看占比 饼图 树地图 堆积图 对比分析&#xff1a;比大…

QML学习(八) Quick中的基础组件:Item,Rectangle,MouseArea说明及使用场景和使用方法

上一篇中我们从设计器里可以看到Qt Quick-Base中有几大基础组件&#xff0c;如下图&#xff0c;这篇文章先介绍下Item&#xff0c;Rectangle&#xff0c;MouseArea这三个的说明及使用场景和使用方法 Item Item 是 QML 中所有可视元素的基类&#xff0c;是一个非常基础和通用的…

万界星空科技质量管理QMS系统具体功能介绍

一、什么是QMS系统&#xff0c;有什么价值&#xff1f; 1、QMS 系统即质量管理系统&#xff08;Quality Management System&#xff09;。 它是一套用于管理和控制企业产品或服务质量的集成化体系。 2、QMS 系统的价值主要体现在以下几个方面&#xff1a; 确保产品质量一致性…

字符串哈希stl解决

题目如下 STL的unordered-set STL的map 谢谢观看&#xff01;&#xff01;&#xff01;

JAVA I/O流练习1

往D盘中的JAVA复习文件夹中写数据&#xff1a; 数据改了一下哈&#xff1a; import java.io.*; import java.util.Scanner; public class Test {public static void main(String[] args) throws IOException {String fileName"D:JAVA复习\\grade.txt";FileWriter w…

英伟达Project Digits赋能医疗大模型:创新应用与未来展望

英伟达Project Digits赋能医疗大模型&#xff1a;创新应用与未来展望 一、引言 1.1 研究背景与意义 在当今数字化时代&#xff0c;医疗行业作为关乎国计民生的关键领域&#xff0c;正面临着前所未有的挑战与机遇。一方面&#xff0c;传统医疗模式在应对海量医疗数据的处理、复…

OpenAI 故障复盘 - 阿里云容器服务与可观测产品如何保障大规模 K8s 集群稳定性

本文作者&#xff1a; 容器服务团队&#xff1a;刘佳旭、冯诗淳 可观测团队&#xff1a;竺夏栋、麻嘉豪、隋吉智 一、前言 Kubernetes(K8s)架构已经是当今 IT 架构的主流与事实标准&#xff08;CNCF Survey[1]&#xff09;。随着承接的业务规模越来越大&#xff0c;用户也在使…