C++ 标准库 iterator 功能 用法运用 详解

news/2025/3/9 19:48:13/文章来源:https://www.cnblogs.com/baisemoshui/p/18761245

C++标准库中的<iterator>头文件提供了一组工具,用于遍历容器中的元素。以下是关于<iterator>的功能、用法及运用的详解:

一、功能概述

<iterator>头文件主要定义了迭代器的类别标签、迭代器适配器以及迭代器操作函数。迭代器是C++标准模板库(STL)中的核心概念之一,它允许程序员以统一的方式访问容器中的元素,而不需要关心容器的具体实现细节。

二、迭代器类别

<iterator>中定义了五种迭代器类别标签,用于标记不同类型的迭代器:

  1. input_iterator_tag:表示输入迭代器,只能进行单次读取操作,不能进行写入操作。
  2. output_iterator_tag:表示输出迭代器,只能进行单次写入操作,不能进行读取操作。
  3. forward_iterator_tag:表示正向迭代器,可以进行读取和写入操作,并且可以向前移动。
  4. bidirectional_iterator_tag:表示双向迭代器,除了可以进行正向迭代器的所有操作外,还可以向后移动。
  5. random_access_iterator_tag:表示随机访问迭代器,除了可以进行双向迭代器的所有操作外,还可以进行随机访问,例如通过下标访问元素。

三、迭代器适配器

迭代器适配器允许将迭代器转换为具有特定功能的迭代器,包括:

  1. back_insert_iterator:用于在容器的末尾插入元素。
  2. front_insert_iterator:用于在容器的开头插入元素,适合std::dequestd::list等容器的头部插入。
  3. insert_iterator:在容器的指定位置插入元素,根据提供的迭代器位置插入。

此外,还有将迭代器转换为反向迭代器的适配器,使迭代器能够从容器的末尾向开头遍历。

四、迭代器操作函数

<iterator>还提供了一些迭代器操作函数,用于控制迭代器的行为:

  1. advance(InputIterator& it, Distance n):将迭代器it向前或向后移动n个位置。
  2. distance(InputIterator first, InputIterator last):计算两个迭代器firstlast之间的元素数量。

五、用法与运用

  1. 定义迭代器

    • 正向迭代器:容器类名::iterator 迭代器名;
    • 常量正向迭代器:容器类名::const_iterator 迭代器名;
    • 反向迭代器:容器类名::reverse_iterator 迭代器名;容器类名::const_reverse_iterator 迭代器名;
  2. 遍历容器

使用迭代器遍历容器是<iterator>头文件的主要应用之一。例如,使用for循环和迭代器遍历std::vector

#include <iostream>
#include <vector>
#include <iterator>int main() {std::vector<int> vec = {1, 2, 3, 4, 5};for (std::vector<int>::iterator it = vec.begin(); it != vec.end(); ++it) {std::cout << *it << " ";}std::cout << std::endl;return 0;
}
  1. 使用迭代器适配器

迭代器适配器可以简化某些操作,如使用std::back_inserter将元素复制到std::vector的末尾:

#include <iostream>
#include <iterator>
#include <vector>
#include <algorithm>int main() {std::vector<int> source = {1, 2, 3};std::vector<int> destination;std::copy(source.begin(), source.end(), std::back_inserter(destination));for (int val : destination) {std::cout << val << " ";}std::cout << std::endl;return 0;
}
  1. 使用迭代器操作函数

迭代器操作函数如std::advancestd::distance可以用于控制迭代器的位置和计算迭代器之间的距离:

#include <iostream>
#include <iterator>
#include <vector>int main() {std::vector<int> vec = {1, 2, 3, 4, 5};auto it = vec.begin();std::advance(it, 2); // 将迭代器向前移动2个位置std::cout << *it << std::endl; // 输出3auto dist = std::distance(vec.begin(), it); // 计算迭代器之间的距离std::cout << "Distance from begin: " << dist << std::endl; // 输出2return 0;
}

六、注意事项

  1. 迭代器分为有效和无效两种状态,类似于指针。有效的迭代器指向某个元素或指向容器中尾元素的下一个位置;无效的迭代器则指向其他所有情况。
  2. 不能对无效迭代器或尾后迭代器进行解引用或递增操作。
  3. 在使用迭代器时,需要确保迭代器的类型与所处理的容器类型相匹配。
  4. 某些对容器的操作可能会使迭代器失效,如std::vectorpush_back操作可能会使指向容器末尾的迭代器失效。

综上所述,<iterator>头文件提供了丰富的迭代器和相关工具,用于遍历和操作C++ STL容器中的元素。掌握这些迭代器的用法和特性,对于提高编程效率和代码质量具有重要意义。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

20242802 2024-2025-2 《网络攻防实践》第二周作业

20242802 2024-2025-2 《网络攻防实践》第二周作业 目录 目录20242802 2024-2025-2 《网络攻防实践》第二周作业1. 实验要求2. 实验相关知识点nmap工具使用3. 实验详细过程3.1 从www.besti.edu.cn、baidu.com、sina.com.cn中选择一个DNS域名进行查询,获取如下信息:3.2尝试获取…

UE5之瞄准视角的俯仰偏移

1.创建瞄准姿势 复制瞄准动画,删除其中多余的帧,只保留瞄准的一帧,将其创建为一个单帧动画。然后将其复制成三份,分别用于表示瞄准三个姿势的up,middle,down。 将middle姿势动画的Additive动画类型修改为网格体空间,因为我们需要在网格空间创建叠加动画。基础姿势修改为…

2K star!三分钟搭建企业级后台系统,这款开源Java框架绝了!

"LikeAdmin Java是基于Spring Boot + Mybatis Plus + Vue 3的快速开发平台,内置RBAC权限管理、工作流引擎、数据可视化、三方登录等核心模块,助力开发者快速构建企业级中后台管理系统"2K star!三分钟搭建企业级后台系统,这款开源Java框架绝了!"LikeAdmin J…

震惊!C++程序真的从main开始吗?99%的程序员都答错了

嘿,朋友们好啊!我是小康。今天咱们来聊一个看似简单,但实际上99%的C++程序员都答错的问题:C++程序真的是从main函数开始执行的吗? 如果你毫不犹豫地回答"是",那恭喜你,你和大多数人一样——掉进了C++的第一个陷阱!别担心,等你看完这篇文章,你就能成为那个与…

11套!量产15W~1000W开关电源电路全套方案资料合集!

本系列小编给大家带来了15W到1000W完整量产版开关电源全系列,全套资料分期给大家分享。每套资料都包含详细的原理图,PCB图,变压器图纸,共模电感图纸,磁环图纸!点击下方链接获取! 15W开关电源方案👆👆👆(点击下载) 25W开关电源方案👆👆👆(点击下载) 30W开…

【每日一题】20250309

我所渴望的,不过是过上一种发自本心的生活,为什么竟会如此困难?【每日一题】已知 \(\odot C\) 过点 \(P(1,2)\),与 \(y\) 轴相交于点 \(Q(0,6)\).若过点 \(Q\) 作 \(\odot C\) 的切线 \(l\),其切线 \(l\) 与 \(x\) 轴平行,则 \(l\) 的方程为_________,\(\odot C\) 的标…

FastAPI Cookie 和 Header 参数完全指南:从基础到高级实战

title: FastAPI Cookie 和 Header 参数完全指南:从基础到高级实战 🚀 date: 2025/3/9 updated: 2025/3/9 author: cmdragon excerpt: 本教程深入探讨 FastAPI 中 Cookie 和 Header 参数的读取与设置,涵盖从基础操作到高级用法。通过详细的代码示例、课后测验和常见错误解…

vim按f5运行代码配置

使vim能够像vscode一样按f5运行代码 效果图let g:last_terminal_buf = -1 " 用于存储上一个终端缓冲区编号 function! RunCurrentFile() " 如果存在上次的终端缓冲区,则删除它 if g:last_terminal_buf != -1 && bufexists(g:last_terminal_buf) silent exec…

DeepSeek + Xmind,1分钟自动把pdf/word文档转成思维导图

DeepSeek加Xmind,1分钟把PDF、Word文档转成思维导图!步骤超简单:第一步:打开DeepSeek,点击“深度思考”,上传你的文档。第二步:告诉DeepSeek“帮我转成思维导图,输出Markdown格式”。第三步:复制代码, 保存文件到桌面文本文件中,修改文件后缀为“.md”。第四步:打开…

Windows平台调试器原理与编写05.内存断点

https://www.bpsend.net/thread-274-1-3.html 内存断点访问断点 写入断点内存写入断点简介:当被调试进程访问,读或写指定内存的时候,程序能够断下来。 思考1:要想将一段内存设为内存断点,最终的目的是让其能够抛异常。调试器是基于异常的一个程序。应该如何实现呢?可以通…

Redis--Lesson01--NoSQL简史

单击MySQL的演进 单机MySQL 在早期互联网时代,也就是90年代以前,一个基本的互联网的访问量不会太大,可以说很多国家和地区都还没有配备互联网,所以在这种情况下的互联网格局使用的数据存储格式就是简单的单机模式,即使用一个数据库的如MySQL库就可以满足日常的数据读写 如…

Excel的快捷键

1、填充序号1~1000(删除后,序号会自动更新) (1)首先在左上角的位置框中输入A1:A1000,然后按Enter回车健,即可选中A1到A1000的单元格。(2)然后在函数框中输入=ROW(),按Ctrl + Enter即可,即可填充1-1000。 本文来自博客园,作者:业余砖家,转载请注明原文链接:http…