stl 迭代器(Iterator)

定义

迭代器(Iterator)是STL(Standard Template Library,标准模板库)中的一个核心概念,用于提供一种通用的方式来遍历容器(如vector、list、map等)中的元素,而无需暴露容器的底层细节。迭代器本质上是一个指针,但它可以指向容器中的元素,而不仅仅是指向内存地址。

迭代器提供了以下基本操作:

  1. begin(): 返回一个指向容器中第一个元素的迭代器。
  2. end(): 返回一个指向容器中最后一个元素之后的位置的迭代器。
  3. *: 解引用运算符,返回迭代器当前指向的元素的值。
  4. ++: 前缀和后缀自增运算符,将迭代器向前移动到下一个元素。
  5. --: 前缀和后缀自减运算符,将迭代器向后移动到前一个元素。
  6. += 和 -=: 用于将迭代器向前或向后移动指定数量的元素。
  7. operator== 和 operator!=: 用于比较两个迭代器是否相等或不相等。

示例

遍历vector

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

STL 迭代器的实现

在STL(Standard Template Library)中,迭代器的实现是高度抽象化的,并且作为模板类存在于各个容器中。由于STL的实现是库的一部分,并且通常作为编译器的标准库提供,所以直接查看STL迭代器的源码可能不是很容易,因为源码通常不包含在标准库中,而是作为库的实现部分,与编译器一起提供。

简单迭代器实现示例

#include <iostream>  // 迭代器类模板  
template<typename T>  
class Iterator {  
public:  // 构造函数  Iterator(T* ptr) : ptr_(ptr) {}  // 解引用运算符  T& operator*() const {  return *ptr_;  }  // 前缀自增运算符  Iterator& operator++() {  ++ptr_;  return *this;  }  // 后缀自增运算符  Iterator operator++(int) {  Iterator temp = *this;  ++ptr_;  return temp;  }  // 不相等运算符  bool operator!=(const Iterator& other) const {  return ptr_ != other.ptr_;  }  private:  T* ptr_; // 指向元素的指针  
};  // 容器类模板  
template<typename T, std::size_t N>  
class Array {  
public:  // 类型别名,方便使用  using iterator = Iterator<T>;  // 获取迭代器指向容器的开始  iterator begin() {  return iterator(data_);  }  // 获取迭代器指向容器的结束(尾后迭代器)  iterator end() {  return iterator(data_ + N);  }  // 数组数据  T data_[N];  
};  int main() {  // 创建一个包含整数的数组容器  Array<int, 5> arr = {1, 2, 3, 4, 5};  // 使用迭代器遍历数组  for (auto it = arr.begin(); it != arr.end(); ++it) {  std::cout << *it << " ";  }  return 0;  
}

在这个示例中,我们定义了一个Iterator类模板,它接受一个类型参数T,代表迭代器将指向的元素类型。迭代器包含了一个指向元素的指针,并重载了*++!=运算符,这些都是STL迭代器通常提供的操作。

我们还定义了一个Array类模板,它包含了一个固定大小的数组和一个使用我们定义的迭代器类型的beginend成员函数。这个Array类模板提供了一个简单的容器接口,可以通过迭代器来访问其元素。

请注意,这个示例只是为了展示迭代器的基本概念和操作,并不能代表STL中迭代器的完整和高效实现。在实际的STL库中,迭代器的实现会更加复杂,并且会考虑到性能优化、类型安全和异常安全等因素。

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

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

相关文章

大小端问题

0. 介绍 大小端计算机存储数据而安排字节的两种顺序。 针对的是字节。 大端与我们平时书写的顺序一致。 1. 大小端的判定 不需要手动判断。 有一个头文件endian.h; 可能会有宏 __BYTE_ORDER __BIG_ENDIAN __LITTLE_ENDIAN通过库来进行判断。 手动判断 根据字节存取的顺序…

【JSON2WEB】07 Amis可视化设计器CRUD增删改查

总算到重点中的核心内容&#xff0c;CRUD也就是增删改查&#xff0c;一个设计科学合理的管理信息系统&#xff0c;95%的就是CRUD&#xff0c;达不到这个比例要重新考虑一下你的数据库设计了。 1 新增页面 Step 1 启动amis-editor Setp 2 新增页面 名称和路径随便命名&#xf…

Dynamo幕墙探究系列(一)

一直想写个系列教程&#xff0c;但是没有那么多时间整理资料&#xff0c;这次呢&#xff0c;先弄个小系列吧&#xff0c;还是和之前差不多的幕墙测试&#xff0c;我们分几节课&#xff0c;一步一步深入研究。 今天先开个小头儿&#xff0c;要弄的&#xff0c;就是下面这么个模型…

对象锁与类锁

不同锁互不影响&#xff0c;共用一个锁&#xff0c;可能会发生阻塞。 1.在修饰静态方法时&#xff0c;锁定的是当前类的 Class 对象&#xff0c;在下面的例子中就是SycTest1.class 2.当修饰非静态方法时&#xff0c;锁定的就是 this 对象&#xff0c;即当前的实例化对象 public…

【Git教程】(四)版本库 —— 存储系统,存储目录,提交对象及其命名、移动与复制~

Git教程 版本库 1️⃣ 一种简单而高效的存储系统2️⃣ 存储目录&#xff1a;Blob 与 Tree3️⃣ 相同数据只存储一次4️⃣ 压缩相似内容5️⃣ 不同文件的散列值相同6️⃣ 提交对象7️⃣ 提交历史中的对象重用8️⃣ 重命名、移动与复制&#x1f33e; 总结 事实上&#xff0c;我们…

keil MDK安装armcc V5编译器

不知道从什么时候开始&#xff0c;Keil MDK默认不支持V5的编译器了&#xff0c;里面默认只有V6的编译器&#xff0c;设置界面跟V5有很大的差异不太熟悉。最可怕的是&#xff0c;之前使用V5编译的工程&#xff0c;换成V6编译器后居然报错...虽然修改一下应该也可以正常编译&…

神经网络基础知识:LeNet的搭建-训练-预测

1.参考视频&#xff1a; 2.1 pytorch官方demo(Lenet)_哔哩哔哩_bilibili 2.总结&#xff1a; &#xff08;1&#xff09;LeNet网络就是 我最开始用来预测mnist数据集的那个网络&#xff0c;简单的2个conv2个maxpool3个linear层 &#xff08;2&#xff09;up主整理的train.py…

SQL面试题(2)

第一题 创建trade_orders表: create table `trade_orders`( `trade_id` varchar(255) NULL DEFAULT NULL, `uers_id` varchar(255), `trade_fee` int(20), `product_id` varchar(255), `time` varchar(255) )ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_…

web自动化笔记九:验证码的处理方式

一、验证码常用的处理方式 ①、说明&#xff1a;Selenium中并没有对验证码处理的方法&#xff0c;在这里我们介绍一下针对验证码的几种常用处理方式 ②、方式&#xff1a; 1&#xff09;、去掉验证码&#xff08;测试环境下采用&#xff09; …

RDD算子介绍

1. RDD算子 RDD算子也叫RDD方法&#xff0c;主要分为两大类&#xff1a;转换和行动。转换&#xff0c;即一个RDD转换为另一个RDD&#xff0c;是功能的转换与补充&#xff0c;比如map&#xff0c;flatMap。行动&#xff0c;则是触发任务的执行&#xff0c;比如collect。所谓算子…

LeetCode 1551.是数组中所有元素相等的最小操作数

存在一个长度为 n 的数组 arr &#xff0c;其中 arr[i] (2 * i) 1 &#xff08; 0 < i < n &#xff09;。 一次操作中&#xff0c;你可以选出两个下标&#xff0c;记作 x 和 y &#xff08; 0 < x, y < n &#xff09;并使 arr[x] 减去 1 、arr[y] 加上 1 &…

Mac专用投屏工具AirServer 7.27 for Mac中文版2024最新图文教程

Mac专用投屏工具AirServer 7.27 for Mac中文版是一款适用于Mac的投屏工具&#xff0c;可以将Mac屏幕快速投影到其他设备上&#xff0c;如电视、投影仪、平板等。 Mac专用投屏工具AirServer 7.27 for Mac中文版具有优秀的兼容性&#xff0c;可以与各种设备配合使用。无论是iPhon…

基于springboot+vue的在线考试系统(源码+论文)

文章目录 目录 文章目录 前言 一、功能设计 二、功能页面 三、论文 前言 现在我国关于在线考试系统的发展以及专注于对无纸化考试的完善程度普遍不高&#xff0c;关于对考试的模式还大部分还停留在纸介质使用的基础上&#xff0c;这种教学模式已不能解决现在的时代所产生的考试…

【MySQL】数据库的操作

【MySQL】数据库的操作 目录 【MySQL】数据库的操作创建数据库数据库的编码集和校验集查看系统默认字符集以及校验规则查看数据库支持的字符集查看数据库支持的字符集校验规则校验规则对数据库的影响数据库的删除 数据库的备份和恢复备份还原不备份整个数据库&#xff0c;而是备…

YOLOv9改进|增加SPD-Conv无卷积步长或池化:用于低分辨率图像和小物体的新 CNN 模块

专栏介绍&#xff1a;YOLOv9改进系列 | 包含深度学习最新创新&#xff0c;主力高效涨点&#xff01;&#xff01;&#xff01; 一、文章摘要 卷积神经网络(CNNs)在计算即使觉任务中如图像分类和目标检测等取得了显著的成功。然而&#xff0c;当图像分辨率较低或物体较小时&…

【LeetCode刷题】146. LRU 缓存

请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类&#xff1a; LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存int get(int key) 如果关键字 key 存在于缓存中&#xff0c;则返回关键字的值&#xff0c;否则返回 -…

全量知识系统问题及SmartChat给出的答复 之9 三套工具之4语法解析器 之2

Q23. 一个语言的语法简约规则 这些规则显示show 在一个给定单词&#xff08;a given word&#xff09;的右边或左边可能出现的单词的类别。句型的多样性variety不是复杂文法&#xff08;a complex grammar&#xff09;的结果&#xff0c;而是简单语法&#xff08;a simple gra…

【InternLM 实战营笔记】浦语·灵笔的图文理解及创作部署、 Lagent 工具调用 Demo

浦语灵笔的图文理解及创作部署 浦语灵笔是基于书生浦语大语言模型研发的视觉-语言大模型&#xff0c;提供出色的图文理解和创作能力&#xff0c;结合了视觉和语言的先进技术&#xff0c;能够实现图像到文本、文本到图像的双向转换。使用浦语灵笔大模型可以轻松的创作一篇图文推…

进程间的通信 -- 共享内存

一 共享内存的概念 1. 1 共享内存的原理 之前我们学过管道通信&#xff0c;分为匿名管道和命名管道&#xff0c;匿名管道通过父子进程的属性继承原理来完成父子进程看到同一份资源的目的&#xff0c;而命名管道则是通过路径与文件名来唯一标识管道文件&#xff0c;来让不同的进…

学习Android的第二十一天

目录 Android ProgressDialog (进度条对话框) 例子 Android DatePickerDialog 日期选择对话框 例子 Android TimePickerDialog 时间选择对话框 Android PopupWindow 悬浮框 构造函数 方法 例子 官方文档 Android OptionMenu 选项菜单 例子 官方文档 Android Progr…