0

0

C++的STL迭代器怎么用_C++中五种迭代器的类型与使用方法

下次还敢

下次还敢

发布时间:2025-12-01 02:33:29

|

372人浏览过

|

来源于php中文网

原创

STL迭代器是访问容器元素的核心工具,分为输入、输出、前向、双向和随机访问五类,功能依次增强。vector等容器支持随机访问迭代器,可高效跳转;list等支持双向迭代器,能前后移动;unordered容器仅支持前向迭代器。使用时需注意迭代器失效问题,避免操作无效指针。算法如find、sort依赖迭代器范围,应合理选择容器与迭代器类型以提升效率。

c++的stl迭代器怎么用_c++中五种迭代器的类型与使用方法

STL(Standard Template Library)中的迭代器是访问容器元素的核心工具,它像指针一样可以遍历、读取或修改容器中的数据。理解迭代器的类型和使用方法,对掌握C++ STL至关重要。

迭代器的基本用法

迭代器通过begin()end()函数获取容器的起始和末尾后一个位置。用循环遍历容器是最常见的操作方式。

例如,使用vector演示基本遍历:

#include 
#include 
using namespace std;

int main() {
    vector nums = {1, 2, 3, 4, 5};
    for (auto it = nums.begin(); it != nums.end(); ++it) {
        cout << *it << " ";
    }
    return 0;
}

输出结果为:1 2 3 4 5。注意end()指向的是最后一个元素的下一个位置,不能直接解引用。

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

五种迭代器类型及其特点

C++中根据功能强弱将迭代器分为五类,每种支持的操作不同。

  • 输入迭代器(Input Iterator):只能向前移动,用于读取数据。常见于istream_iterator,支持单次遍历。
  • 输出迭代器(Output Iterator):只能向前移动,用于写入数据。如ostream_iterator,不可读取内容。
  • 前向迭代器(Forward Iterator):可多次读写,只能++向前。适用于slist、unordered_map等容器。
  • 双向迭代器(Bidirectional Iterator):支持++和--,可前后移动。list、set、map等使用此类。
  • 随机访问迭代器(Random Access Iterator):功能最强,支持+、-、[]、比较等操作。vector、deque、array支持。

功能由弱到强依次为:输入/输出 → 前向 → 双向 → 随机访问。高级迭代器可替代低级用途。

Copy.ai
Copy.ai

Copy.ai 是一个人工智能驱动的文案生成器

下载

不同容器对应的迭代器类型

每种容器提供的迭代器能力不同,选择合适容器影响算法使用。

  • vector、deque、array → 随机访问迭代器
  • list、set、multiset、map、multimap → 双向迭代器
  • unordered系列容器 → 前向迭代器
  • istream_iterator → 输入迭代器
  • ostream_iterator → 输出迭代器

比如vector支持it + 5跳转,而list不支持,必须用std::advance(it, 5)逐步移动。

常用操作与注意事项

迭代器使用中需注意有效性与操作限制。

  • 避免使用已失效的迭代器,如删除元素后原迭代器可能无效。
  • 修改容器可能导致迭代器失效,特别是vector在扩容时所有迭代器失效。
  • 尽量使用auto简化声明,如auto it = vec.begin();
  • 算法库如findsort依赖迭代器作为参数范围。

例如,使用find查找元素:

auto it = find(nums.begin(), nums.end(), 3);
if (it != nums.end()) {
    cout << "找到元素:" << *it;
}

基本上就这些。掌握这五类迭代器的区别和适用场景,能更高效地使用STL容器与算法。

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

386

2023.09.04

golang map内存释放
golang map内存释放

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

75

2025.09.05

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

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

33

2025.11.16

golang map原理
golang map原理

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

59

2025.11.17

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

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

37

2025.11.27

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

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

182

2023.11.24

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

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

402

2023.08.14

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

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

323

2023.10.09

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

ECMAScript6 / ES6---十天技能课堂
ECMAScript6 / ES6---十天技能课堂

共25课时 | 1.9万人学习

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

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