0

0

c++ STL中的迭代器是什么_c++ STL迭代器使用方法

冰火之心

冰火之心

发布时间:2025-10-06 23:18:02

|

882人浏览过

|

来源于php中文网

原创

迭代器是C++ STL中用于访问容器元素的通用机制,类似指针,支持遍历和操作元素而不暴露内部结构。每种容器提供对应迭代器类型,如vector::iterator、list::iterator等,可通过*it读取值、++it移动位置。STL定义五类迭代器:输入、输出、前向、双向和随机访问迭代器,功能依次增强。常用成员函数包括begin()、end()、rbegin()、rend(),用于获取迭代器。遍历时需避免解引用end(),并注意插入删除可能导致迭代器失效。推荐使用const迭代器(cbegin/cend)保护数据,算法如find、sort以迭代器区间[first, last)为参数。示例显示用for循环或范围for遍历vector,以及用find查找元素,体现迭代器在泛型编程中的核心作用。

c++ stl中的迭代器是什么_c++ stl迭代器使用方法

迭代器(Iterator)是 C++ STL 中用于访问容器元素的一种通用机制,它类似于指针,可以指向容器中的某个元素,并通过递增、递减等操作遍历整个容器。使用迭代器可以让算法与具体容器解耦,提高代码的通用性和可复用性。

迭代器的基本概念

迭代器是一种抽象概念,代表了对容器中元素的访问能力。每种 STL 容器都提供了相应的迭代器类型,比如 vector::iteratorlist::iterator 等。通过迭代器,你可以:

  • 读取或修改元素值
  • 遍历容器中的所有元素
  • 在不暴露容器内部结构的前提下进行操作

迭代器的行为类似于指针:

*it     // 获取当前指向元素的值
++it    // 指向下一个元素
it++    // 先使用当前值,再移动到下一个
--it    // 指向前一个元素(部分支持)
it == it2 // 判断两个迭代器是否指向同一位置
it != it2

常见迭代器类型

根据功能强弱,STL 将迭代器分为五类:

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

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

基本使用方法

大多数容器提供以下成员函数来获取迭代器:

Speech Studio
Speech Studio

微软语音服务,提供语音到文本、文本到语音和语音翻译功能。

下载
  • begin():返回指向第一个元素的迭代器
  • end():返回指向末尾之后位置的迭代器(注意不是最后一个元素)
  • rbegin() / rend():反向迭代器,用于逆序遍历

示例:使用迭代器遍历 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

也可以使用范围 for 循环(底层仍基于迭代器):

for (const auto& val : vec) {
    cout << val << " ";
}

注意事项和技巧

使用迭代器时需注意以下几个关键点:

  • 不要对 end() 返回的迭代器解引用 —— 它指向的是“尾后”,无实际值
  • 插入或删除元素可能导致迭代器失效(尤其是 vector 在扩容或删除时)
  • 尽量使用 const 迭代器(cbegin/cend)当不需要修改元素时
  • 算法库(如 find、sort)通常以迭代器区间作为参数,形式为 [first, last)

示例:使用 find 查找元素

#include 
auto it = find(vec.begin(), vec.end(), 3);
if (it != vec.end()) {
    cout << "找到元素:" << *it << endl;
}
基本上就这些。掌握迭代器是使用 STL 的基础,理解其行为和限制能让代码更安全高效。

相关专题

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

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

383

2023.09.04

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

520

2023.09.20

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

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

180

2023.11.24

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

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

395

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()方法打开连接即可。

385

2023.10.16

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

连接的方法:1、使用ADO连接数据库;2、使用DSN连接数据库;3、使用连接字符串连接数据库。想了解更详细的asp连接access数据库的方法,可以阅读本专题下面的文章。

119

2023.10.18

access和trunk端口的区别
access和trunk端口的区别

access和trunk端口的区别是Access端口用于连接终端设备,提供单个VLAN的接入,而Trunk端口用于连接交换机之间,提供多个VLAN的传输;Access端口只传输属于指定VLAN的数据,而Trunk端口可以传输多个VLAN的数据,并使用VLAN标签进行区分。想了解更多access和trunk端口相关内容,可以阅读本专题下面的文章。

319

2023.10.31

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

3

2026.01.09

热门下载

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

精品课程

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

共32课时 | 3.5万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

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

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