C++之迭代器(Iterator)篇

C++之迭代器(Iterator)篇迭代器 Iterator 的介绍背景 指针可以用来遍历存储空间连续的数据结构 但是对于存储空间费连续的 就需要寻找一个行为类似指针的类 来对非数组的数据结构进行遍历 定义 迭代器提供对一个容器中的对象的访问方法 并且定义了容器中对象的范围 迭代器 Iterator 是指针 pointer 的泛化 它允许程序员用相同的方式处理不同的数据结构 容器 1 迭代器类似于 C 语言里面的指针类

  1. 迭代器(Iterator)的介绍
    背景:指针可以用来遍历存储空间连续的数据结构,但是对于存储空间费连续的,就需要寻找一个行为类似指针的类,来对非数组的数据结构进行遍历。
    定义:迭代器是一种检查容器内元素并遍历元素的数据类型。
    迭代器提供对一个容器中的对象的访问方法,并且定义了容器中对象的范围
    迭代器(Iterator)是指针(pointer)的泛化,它允许程序员用相同的方式处理不同的数据结构(容器)。
    (1)迭代器类似于C语言里面的指针类型,它提供了对对象的间接访问。
    (2)指针是C语言中的知识点,迭代器是C++中的知识点。指针较灵活,迭代器功能较丰富。
    (3)迭代器提供一个对容器对象或者string对象的访问方法,并定义了容器范围






  2. 迭代器和指针的区别:
    容器和string有迭代器类型同时拥有返回迭代器的成员。如:容器有成员begin和end,其中begin成员复制返回指向第一个元素的迭代器,而end成员返回指向容器尾元素的下一个位置的迭代器,也就是说end指示的是一个不存在的元素,所以end返回的是尾后迭代器
  3. 容器迭代器的使用
    每种容器类型都定义了自己的迭代器类型,如vector:vector< int>:: iterator iter;//定义一个名为iter的变量,数据类型是由vector< int>定义的iterator 类型。简单说就是容器类定义了自己的iterator类型,用于访问容器内的元素。每个容器定义了一种名为iterator的类型,这种类型支持迭代器的各种行为
    常用迭代器类型如下:
    这里写图片描述
    如上图所示,迭代器类型主要支持两类,随机访问和双向访问。其中vector和deque支持随机访问,list,set,map等支持双向访问。
    1)随机访问:提供了对数组元素进行快速随机访问以及在序列尾部进行快速插入和删除操作。
    2)双向访问:插入和删除所花费的时间是固定的,与位置无关。





  4. 迭代器的操作
    1、所有迭代器:
    这里写图片描述
    2、双向迭代器:
    这里写图片描述
    3、输入迭代器:
    列表内容
    4、输出迭代器
    这里写图片描述
    5、随机迭代器
    这里写图片描述









版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/206122.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月19日 下午4:25
下一篇 2026年3月19日 下午4:25


相关推荐

  • Mysql 远程连接权限错误1045问题

    #今天新安装mysql以后,由于没有勾选Enablerootaccessfromremotemachines而再连接数据库时出现了以下问题走了许多绕路,在这里做下笔记。网上查阅资料很多说是密码问题,我一开始也是照着网上的方法去服务器上修改密码,然后本地连接,结果还是出错,才发现是混淆了一些东西。数据库的root账户分两种,一种是本地,一种是远程:我需要修改的是远程root密码…

    2022年4月9日
    62
  • 数值型和字符型数据的字节数和取值范围

    数值型和字符型数据的字节数和取值范围数值型和字符型数据的字节数和取值范围如下表所示

    2026年3月17日
    2
  • 王艳茹网课答案创业基础超星尔雅答案2021

    王艳茹网课答案创业基础超星尔雅答案2021创业的概念与功能1【单选题】下列对创业定义理解不正确的一项是(B)A、创业者通过资源整合来达到创业目标B、创业伴随新行业的出现C、寻求机会是产生创业活动的重要一环D、创业伴随新价值的产生创业的要素和阶段1【单选题】创业的关键要素不包括(C)A、机会B、团队C、技术D、资源2【多选题】创业可分为哪些阶段(ABCD)A、机会识别B、资源整合C、新企业创办D、企业生存3【多选题】下列说法中正确的有(ABC)A、商业机会是创业过程的重…

    2022年6月6日
    68
  • netsh命令

    netsh命令netsh NetworkShell 是一个 windows 系统本身提供的功能强大的网络配置命令行工具 导出配置脚本 netsh cinterfaceip gt c interface txt 导入配置脚本 netsh fc interface txt Netsh 是命令行脚本实用工具 它允许从本地或远程显示或修改当前正在运行的计算机的网络配置 Netsh 还提供了一个脚本功能 对于指定计算机 可以通过此功能以批处理模式运行一组命令 为了存档或配置其他服务器 Nets

    2026年3月26日
    2
  • 访问远程MySQL数据库的方法

    访问远程MySQL数据库的方法

    2021年9月19日
    49

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号