0

0

c++中iterator迭代器怎么用_iterator迭代器使用详解

尼克

尼克

发布时间:2025-09-26 10:52:02

|

867人浏览过

|

来源于php中文网

原创

迭代器是C++ STL中用于遍历容器元素的通用机制,其行为类似指针,支持解引用、自增等操作。不同容器提供不同类型迭代器:vector支持随机访问迭代器,list为双向迭代器,map迭代器指向键值对,需通过first和second访问键值。常见操作包括begin()、end()、*it、++it等。使用时需避免失效迭代器、不越界解引用,并推荐使用auto简化声明,掌握迭代器是理解STL的关键。

c++中iterator迭代器怎么用_iterator迭代器使用详解

在C++中,迭代器(iterator)是用于遍历容器元素的一种通用机制。它类似于指针,可以指向容器中的某个元素,并通过自增、解引用等操作访问数据。使用迭代器可以让算法与具体容器类型解耦,提高代码的通用性和可维护性。

什么是迭代器

迭代器是一种对象,它提供了一种统一的方式来访问标准模板库(STL)容器中的元素,比如 vector、list、set、map 等。每种容器都定义了自己的迭代器类型,但使用方式基本一致。

常见的迭代器操作包括:

  • *it:解引用,获取当前指向的元素值
  • ++it 或 it++:移动到下一个元素
  • it == other:判断两个迭代器是否相等
  • it != other:判断是否不相等
  • it = container.begin():指向第一个元素
  • it = container.end():指向最后一个元素的后一个位置(哨兵位置)

常见容器的迭代器使用示例

以下是一些常用容器中迭代器的基本用法。

立即学习C++免费学习笔记(深入)”;

1. vector 的迭代器

vector 支持随机访问迭代器,可以高效地进行遍历和随机访问。

#include 
#include 
using namespace std;

int main() {
    vector vec = {1, 2, 3, 4, 5};

    // 使用迭代器遍历
    for (auto it = vec.begin(); it != vec.end(); ++it) {
        cout << *it << " ";
    }
    cout << endl;

    return 0;
}
输出:1 2 3 4 5

2. list 的迭代器

list 是双向链表,支持双向迭代器。

造梦阁AI
造梦阁AI

AI小说推文一键成片,你的故事值得被看见

下载

#include 
#include 
using namespace std;

int main() {
    list names = {"Alice", "Bob", "Charlie"};

    for (auto it = names.begin(); it != names.end(); ++it) {
        cout << *it << " ";
    }
    cout << endl;

    return 0;
}
输出:Alice Bob Charlie

3. map 的迭代器

map 的迭代器指向的是键值对(pair),需要用 firstsecond 访问。

#include 
#include 
using namespace std;

int main() {
    map student = {{101, "Tom"}, {102, "Jerry"}};

    for (auto it = student.begin(); it != student.end(); ++it) {
        cout << "ID: " << it->first 
             << ", Name: " << it->second << endl;
    }

    return 0;
}
输出:
ID: 101, Name: Tom
ID: 102, Name: Jerry

迭代器的种类

C++ 中根据功能强弱将迭代器分为五类:

  • 输入迭代器(Input Iterator):只能读取一次数据,支持前向移动
  • 输出迭代器(Output Iterator):只能写入一次数据,支持前向移动
  • 前向迭代器(Forward Iterator):可多次读写,仅支持 ++ 操作
  • 双向迭代器(Bidirectional Iterator):支持 ++ 和 --,如 list、set
  • 随机访问迭代器(Random Access Iterator):支持 +n、-n、[] 等操作,如 vector、deque

不同容器提供的迭代器类型不同,决定了能执行的操作范围。

使用注意事项

使用迭代器时要注意以下几点:

  • 不要使用失效的迭代器:例如在 vector 插入元素后,原有迭代器可能失效
  • end() 返回的是尾后位置,不能解引用
  • 循环中尽量使用 ++it 而非 it++:避免临时对象开销(虽然现代编译器会优化)
  • 优先使用 auto 简化声明:如 auto it = vec.begin();

基本上就这些。掌握迭代器的使用是学习 STL 的关键一步,理解其原理有助于写出更通用、高效的 C++ 代码。

相关专题

更多
golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

28

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

59

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.27

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

180

2023.11.24

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

400

2023.08.14

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

322

2023.10.09

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

392

2023.10.16

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

6

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 6.7万人学习

C 教程
C 教程

共75课时 | 4万人学习

C++教程
C++教程

共115课时 | 12.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号