C++初学者指南-5.标准库(第二部分)–特殊迭代器

news2025/1/10 3:02:46

C++初学者指南-5.标准库(第二部分)–特殊迭代器

文章目录

  • C++初学者指南-5.标准库(第二部分)–特殊迭代器
    • 容器操纵器
      • std::insert_iterator\<Container>
      • std::back_insert_iterator\<Container>
      • std::front_insert_iterator\<Container>
    • I/O 流迭代器
      • std::istream_iterator\<ValueType>
    • 标准算法兼容性
    • 相关内容

#include <iterator>

  • 特殊输入迭代器 = 数据源

    • 提取数据:value = *it
    • 前进位置:++IT
  • 特殊输出迭代器 = 数据接收器

    • 插入数据: *it++ = value
  • 主要与标准算法结合使用,例如:
    std::copy(@source_begin, @source_end, @target_begin) → @target_end
    std::ranges::copy(source_range, @target_begin) → {@source_end, @target_end} [C++20]

  • 特殊的输入/输出迭代器不能与需要前向、双向或随机访问迭代器的算法一起使用。

容器操纵器

  • 可用于将新元素插入容器中
  • (只有)在事先不知道插入元素数量的情况下才有用
  • 在性能关键的代码中避开:
    提前预留容器内存,并使用普通迭代器。

std::insert_iterator<Container>

  • 输出迭代器:数据接收器 / 目标
  • 单遍:每个位置只能访问一次
  • 在构建时存储对容器和插入位置的引用
  • *it = value 相当于在容器上调用 insert(position, value)
  • * 和 ++ 是空操作,* 只是返回迭代器本身的引用。

最好通过方便函数获取:
std::inserter(container, position)
→ std::insert_iterator{container, position}
cppreference:std::insert_iterator
cppreference:std::inserter
在这里插入图片描述
运行示例代码

std::back_insert_iterator<Container>

  • 输出迭代器:数据接收器 / 目标
  • 单遍:每个位置只能访问一次
  • 在构造时存储对容器的引用
  • *it = value 相当于对容器调用 .push_back(value)
  • * 和 ++ 是空操作,* 只返回对迭代器本身的引用

最好通过方便函数获取:
std::back_inserter(container)
→ std::back_insert_iterator{container}
cppreference:std::back_insert_iterator
cppreference:std::back_inserter
在这里插入图片描述
运行示例代码

std::front_insert_iterator<Container>

  • 输出迭代器:数据接收器 / 目标
  • 单遍:每个位置只能访问一次
  • 在构造时存储对容器的引用
  • *it = value 相当于对容器调用 push_front(value)
  • * 和 ++ 是空操作,* 只返回对迭代器本身的引用

最好通过方便函数获取:
std::front_inserter(container)
→ std::front_insert_iterator{container}
cppreference:std::back_insert_iterator
cppreference:std::back_inserter
在这里插入图片描述
运行示例代码

I/O 流迭代器

  • 允许使用流作为标准算法的源或目标
  • 在性能关键的代码中应该避免使用

### std::ostream_iterator <ValueType>

  • 输出迭代器:数据接收器/目标
  • 单遍:每个位置只能访问一次
  • 构造时存储对输出流的引用
  • *it = value 将值放入流中
  • * 和 ++ 是无操作的,* 仅返回对迭代器本身的引用
    cppreference: std::ostream_iterator
    在这里插入图片描述
    运行示例代码

std::istream_iterator<ValueType>

  • 输入迭代器:数据源
  • 单遍:每个位置只能访问一次
  • 构造时存储对输出流的引用
  • *it 它从流中获取当前值
  • ++it 它将流推进到下一个值
  • 一个没有参数构造的istream_iterator可以用来表示范围的结束
    cppreference: std::istream_iterator

在这里插入图片描述
运行示例代码

标准算法兼容性

下表列出了标准算法 与上面介绍的特殊迭代器的兼容性。
由于特殊迭代器只能作为输入或输出迭代器,因此它们无法与需要前向、双向或随机访问迭代器的算法一起使用。
在这里插入图片描述

相关内容

迭代器介绍
容器遍历
标准库范围复制算法
标准库顺序容器
标准库顺序视图
标准库关联容器

附上原文链接
如果文章对您有用,请随手点个赞,谢谢!^_^

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

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

相关文章

2024大二上js高级+ES6学习9.29(深/浅拷贝,正则表达式,let/const,解构赋值,箭头函数,剩余参数)

9.29.2024 1.浅拷贝和深拷贝 Es6的语法糖&#xff1a;用assign将obj对象浅拷贝给o对象。 把数组写在前面是因为数组也是对象 2.正则表达式 创建和检测正则表达式 正则表达式的使用直接跳过&#xff0c;等要用时现查现用 3.ES6 4.let关键字 块级作用域是指在一个{}l里 变量提…

Python | Leetcode Python题解之第441题排列硬币

题目&#xff1a; 题解&#xff1a; class Solution:def arrangeCoins(self, n: int) -> int:left, right 1, nwhile left < right:mid (left right 1) // 2if mid * (mid 1) < 2 * n:left midelse:right mid - 1return left

四、Java 基础语法

一、Java 的类、对象、方法和实例变量 一个 Java 程序可以认为是一系列对象的集合&#xff0c;而这些对象通过调用彼此的方法来协同工作。下面简要介绍下类、对象、方法和实例变量的概念。对象&#xff1a;对象是类的一个实例&#xff0c;有状态&#xff08;实例变量&#xff…

MySQL基础练习题49-低质量的问题

目录 题目 准备数据 分析数据 总结 题目 找出 低质量 问题的 ID 集合。如果一个力扣问题的喜欢率&#xff08;喜欢数除以总投票数&#xff09;严格低于 60% &#xff0c;则该问题为低质量问题。 按 problem_id 升序排列返回结果表。 准备数据 Create table If Not Exis…

深度学习基础—卷积神经网络示例

1.卷积神经网络的结构 在之前的博客《深度学习—简单的卷积神经网络》&#xff0c;仅由卷积层构成网络的全部&#xff0c;这还不是标准的网络结构&#xff0c;本文将继续介绍标准的卷积神经网络结构有哪些&#xff1f; 深度学习基础—简单的卷积神经网络https://blog.csdn.net…

STM32-按键控制LED 光敏传感器控制蜂鸣器(江协笔记)

1、按键 2、常见传感器模块 R1 定值电阻 N1 传感器电阻。对于光敏传感器来说&#xff0c;相当于光敏电阻&#xff1b;...... C(滤波电容) 给中间的电压输出进行滤波&#xff0c;用于滤除一些干扰&#xff0c;保证输出电压波形的平滑&#xff08;保持电路稳定&#xff09; …

Pikachu-暴力破解-验证码绕过(on client)

访问页面&#xff0c; 从burpsuite 上看到返回的源代码&#xff1b; 验证码生成时通过 createCode 方法生成&#xff0c;在前端页面生成&#xff1b; 同时也是在前端做的校验&#xff1b; 直接验证&#xff1b;F12 -- 网络&#xff0c;随便输入个账号、密码、验证码&#xff0…

多维度柱状图绘制

图形结果 绘制过程 数据如下 调整柱子宽度 Z轴设置 、 配色表

开源链动2+1模式AI智能名片S2B2C商城小程序源码:流量运营中的价值创造与用户影响

摘要&#xff1a;本文深入探讨在开源链动21模式AI智能名片S2B2C商城小程序源码的背景下&#xff0c;流量的激活、信任建立、圈层沉淀以及裂变等流量运营现象。分析流量运营成本与用户消费意识的关系&#xff0c;强调内容在赋予流量价值以影响用户感知和消费判断方面的重要性。 …

基于yolov8深度学习的120种犬类检测与识别系统python源码+onnx模型+评估指标曲线+精美GUI界面目标检测狗类检测犬类识别系统

【算法介绍】 基于YOLOv8深度学习的120种犬类检测与识别系统是一款功能强大的工具&#xff0c;该系统利用YOLOv8深度学习框架&#xff0c;通过21583张图片的训练&#xff0c;实现了对120种犬类的精准检测与识别。 该系统基于Python与PyQt5开发&#xff0c;具有简洁的UI界面&a…

当AI成为作家,人工智能在写作领域的崛起

AI写作技术的应用正在多个领域展现出其强大的潜力和价值&#xff0c;它不仅极大地提升了内容创作的效率&#xff0c;还为创作者提供了一个全新的创作伙伴。 随着技术的进步&#xff0c;AI写作工具越来越能够理解复杂的语境和用户需求&#xff0c;帮助创作者生成高质量的内容。…

DpCas 镜头场景分割 Scene Segmentation

开源项目 - DpCas 镜头场景分割 Scene Segmentation 开源项目地址&#xff1a;https://gitcode.net/EricLee/dpcas 示例&#xff1a;

写出第一个php程序

一、打开vscode&#xff0c;下载chinese插件、php debug、phpintelephense 二、下载完上方图片插件后&#xff0c;创建一个PHP文件&#xff0c;1.php 三、执行命令&#xff0c;成功输出

pytorch搭建神经网络(手搓方法)

假如我们有一个数据集形状为(348,14)。即有348个记录&#xff0c;每个记录有14个特征值。 我们想要搭建一个如下的神经网络&#xff1a; import torch import numpy as np# 创建数据集: 每个样本有14个特征 x_train np.array([[0.5, -1.2, 0.3, 0.8, 1.0, -0.5, 2.3, 1.2, -0…

在Ubuntu 20.04中安装CARLA

0. 引言 CARLA (Car Learning to Act) 是一款开源自动驾驶模拟器&#xff0c;其支持自动驾驶系统全管线的开发、训练和验证&#xff08;Development, Training, and Validation of autonomous driving systems&#xff09;。Carla提供了丰富的数字资产&#xff0c;例如城市布局…

前端编程艺术(2)----CSS

目录 1.CSS 2.CSS引入 3.选择器 1.标签选择器 2.类选择器 3.id选择器 4.属性选择器 5.后代选择器 5.直接子元素选择器 6.伪类选择器 链接相关 动态伪类 结构化伪类 否定伪类 其他伪类 UI元素状态伪类 4.字体 1.font-family 2.font-size 3.font-style 4.fo…

Linux查找隐藏病毒进程

工具连接 下载工具不要分&#xff0c;随便下 下载后修改工具名&#xff1a;如修改为lsof、ps、top等并为工具加入执行权限 2、 直接执行即可&#xff0c;与正常命令用法一致&#xff08;截图如下&#xff09;

足球预测推荐软件:百万数据阐述百年足球历史-大数据模型量化球员成就值

我开始创建这个模型是从梅西22世界杯夺冠第二天开始准备的&#xff0c;当时互联网上充斥了太多了个人情感的输出&#xff0c;有的人借题对C罗冷嘲热讽&#xff0c;有的人质疑梅西的阿根廷被安排夺冠不配超越马拉多纳做GOAT。作为一个从2002年开始看球的球迷&#xff0c;说实话有…

linux自用小手册

一、GDB常用命令 想用gdb调试C或C程序&#xff0c;编译时需要加-g选项&#xff0c;编译出的文件为debug状态&#xff08;如果不加则是release状态&#xff09;&#xff0c;且不可以加-O选项进行优化。 命令简写解释set args 设置程序传递的参数 例&#xff1a;./demo -v value…

【MySQL报错】---Data truncated for column ‘age‘ at row...

目录 一、前言二、问题分析三、解决办法 一、前言 欢迎大家来到权权的博客~欢迎大家对我的博客进行指导&#xff0c;有什么不对的地方&#xff0c;我会及时改进哦~ 博客主页链接点这里–>&#xff1a;权权的博客主页链接 二、问题分析 问题一修改表结构 XXX 为 not n…