C++笔记之迭代器失效问题处理
C++笔记之迭代器失效问题处理
code review!
参考博文:C++STL迭代器失效的几种情况总结
文章目录
- C++笔记之迭代器失效问题处理
- 一.使用返回新迭代器的插入和删除操作
- 二.对`std::vector` 来说,擦除(erase)元素会导致迭代器失效
一.使用返回新迭代器的插入和删除操作
二.对std::vector
来说,擦除(erase)元素会导致迭代器失效
对于 std::vector
来说,擦除(erase)元素会导致迭代器失效。具体而言,当从 std::vector
中删除元素时,原来指向被删除元素的迭代器就会失效,进而可能引起未定义行为。
处理迭代器失效的方法取决于具体的情况和需求。以下是一些处理迭代器失效的常见方法:
- 使用返回新迭代器的擦除操作:
std::vector
的erase()
函数会返回一个指向下一个有效元素的迭代器。因此,在擦除元素后,可以使用返回的新迭代器继续遍历容器。
#include <iostream>
#include <vector>int main() {std::vector<int> myVector = {1, 2, 3, 4, 5};for (auto it = myVector.begin(); it != myVector.end(); ) {if (*it % 2 == 0) {it = myVector.erase(it); // 擦除元素,并返回指向下一个元素的新迭代器} else {++it; // 移动迭代器到下一个位置}}// 使用新迭代器遍历容器for (auto it = myVector.begin(); it != myVector.end(); ++it) {std::cout << *it << " ";}return 0;
}
- 使用标准算法:C++ 提供了一些标准算法,如
std::remove_if
,用于在不失效迭代器的情况下移除满足条件的元素。
#include <iostream>
#include <vector>
#include <algorithm>int main() {std::vector<int> myVector = {1, 2, 3, 4, 5};myVector.erase(std::remove_if(myVector.begin(), myVector.end(), [](int n) {return n % 2 == 0;}), myVector.end());// 使用迭代器遍历容器for (auto it = myVector.begin(); it != myVector.end(); ++it) {std::cout << *it << " ";}return 0;
}
在此例中,我们使用 std::remove_if
来将满足条件的元素移到容器末尾,并返回一个指向新的逻辑尾部的迭代器,然后再使用 erase()
擦除这些元素。
总之,在删除 std::vector
的元素时,尽量使用返回新迭代器的擦除操作或者标准算法,以确保迭代器不会失效。在使用 erase()
函数后,使用返回的新迭代器来继续遍历容器。如果你需要在循环中擦除元素,请特别注意处理迭代器的有效性。
相关文章:
![](https://img-blog.csdnimg.cn/ffaf045f88a94b4e9ebfa935edbdc42e.png)
C++笔记之迭代器失效问题处理
C笔记之迭代器失效问题处理 code review! 参考博文:CSTL迭代器失效的几种情况总结 文章目录 C笔记之迭代器失效问题处理一.使用返回新迭代器的插入和删除操作二.对std::vector 来说,擦除(erase)元素会导致迭代器失效 一.使用返回…...
![](https://www.ngui.cc/images/no-images.jpg)
Tomcat的startup.bat文件出现闪退问题
对于双击Tomcat的startup.bat文件出现闪退问题,您提供的分析是正确的。主要原因是Tomcat需要Java Development Kit (JDK)的支持,而如果没有正确配置JAVA_HOME环境变量,Tomcat将无法找到JDK并启动,从而导致闪退。 以下是解决该问题…...
![](https://www.ngui.cc/images/no-images.jpg)
JAVA8-lambda表达式8:在设计模式-模板方法中的应用
传送门 JAVA8-lambda表达式1:什么是lambda表达式 JAVA8-lambda表达式2:常用的集合类api JAVA8-lambda表达式3:并行流,提升效率的利器? JAVA8-lambda表达式4:Optional用法 java8-lambda表达式5…...
![](https://www.ngui.cc/images/no-images.jpg)
React之组件间通信
React之组件间通信 组件通信: 简单讲就是组件之间的传值,包括state、函数等 1、父子组件通信 父组件给子组件传值 核心:1、自定义属性;2、props 父组件中: 自定义属性传值 import Header from /components/Headerconst Home ()…...
![](https://img-blog.csdnimg.cn/5805e65260744af7a2a4859c2609f6a4.png)
【MATLAB第58期】基于MATLAB的PCA-Kmeans、PCA-LVQ与BP神经网络分类预测模型对比
【MATLAB第58期】基于MATLAB的PCA-Kmeans、PCA-LVQ与BP神经网络分类预测模型对比 一、数据介绍 基于UCI葡萄酒数据集进行葡萄酒分类及产地预测 共包含178组样本数据,来源于三个葡萄酒产地,每组数据包含产地标签及13种化学元素含量,即已知类…...
CF1833 A-E
A题 题目链接:https://codeforces.com/problemset/problem/1833/A 基本思路:for循环遍历字符串s,依次截取字符串s的子串str,并保存到集合中,最后输出集合内元素的数目即可 AC代码: #include <iostrea…...
![](https://img-blog.csdnimg.cn/e5e5a43255934fe7b8964923923acc29.png)
【深度学习】【Image Inpainting】Generative Image Inpainting with Contextual Attention
Generative Image Inpainting with Contextual Attention DeepFillv1 (CVPR’2018) 论文:https://arxiv.org/abs/1801.07892 论文代码:https://github.com/JiahuiYu/generative_inpainting 论文摘录 文章目录 效果一览摘要介绍论文贡献相关工作Image…...
![](https://img-blog.csdnimg.cn/63e7e545bfc4431eac77454d85c2b19e.png)
二维深度卷积网络模型下的轴承故障诊断
1.数据集 使用凯斯西储大学轴承数据集,一共有4种负载下采集的数据,每种负载下有10种 故障状态:三种不同尺寸下的内圈故障、三种不同尺寸下的外圈故障、三种不同尺寸下的滚动体故障和一种正常状态 2.模型(二维CNN) 使…...
![](https://img-blog.csdnimg.cn/9d2d351056144dcaafd1e464d0ddbb74.png)
redis突然变慢问题定位
CPU 相关:使用复杂度过高命令、O(N)的这个N,数据的持久化,都与耗费过多的 CPU 资源有关 内存相关:bigkey 内存的申请和释放、数据过期、数据淘汰、碎片整理、内存大页、内存写时复制都与内存息息相关 磁盘…...
![](https://img-blog.csdnimg.cn/33f4d9d2757d42c6939288a59df34316.png)
React井字棋游戏官方示例
在本篇技术博客中,我们将介绍一个React官方示例:井字棋游戏。我们将逐步讲解代码实现,包括游戏的组件结构、状态管理、胜者判定以及历史记录功能。让我们一起开始吧! 项目概览 在这个井字棋游戏中,我们有以下组件&am…...
![](https://img-blog.csdnimg.cn/dff581e08a334090abc385d4e4b9f603.png#pic_center)
七大经典比较排序算法
1. 插入排序 (⭐️⭐️) 🌟 思想: 直接插入排序是一种简单的插入排序法,思想是是把待排序的数据按照下标从小到大,依次插入到一个已经排好的序列中,直至全部插入,得到一个新的有序序列。例如:…...
![](https://img-blog.csdnimg.cn/img_convert/a7cc5ddcce79edff1d79bfa39d4c16bb.png)
【点云处理教程】03使用 Python 实现地面检测
一、说明 这是我的“点云处理”教程的第3篇文章。“点云处理”教程对初学者友好,我们将在其中简单地介绍从数据准备到数据分割和分类的点云处理管道。 在上一教程中,我们在不使用 Open3D 库的情况下从深度数据计算点云。在本教程中,我们将首先…...
![](https://img-blog.csdnimg.cn/2c103ef3daf647faa471bdab140a7f0c.png)
Python 日志记录:6大日志记录库的比较
Python 日志记录:6大日志记录库的比较 文章目录 Python 日志记录:6大日志记录库的比较前言一些日志框架建议1. logging - 内置的标准日志模块默认日志记录器自定义日志记录器生成结构化日志 2. Loguru - 最流行的Python第三方日志框架默认日志记录器自定…...
![](https://www.ngui.cc/images/no-images.jpg)
最近遇到一些问题的解决方案
最近遇到一些问题的解决方案 SpringBoot前后端分离参数传递方式总结Java8版本特性讲解idea使用git更新代码 : update project removeAll引发得java.lang.UnsupportedOperationException异常Java的split()函数用多个不同符号分割 Aspect注解切面demo 抽取公共组件,使…...
![](https://www.ngui.cc/images/no-images.jpg)
封装hutool工具生成JWT token
private static final String KEY "abcdef";/*** 生成token** param payload 可以存放用户的一些信息,不要存放敏感字段* return*/public static String createToken(Map<String, Object> payload) {//十分重要,不禁用发布到生产环境无…...
![](https://img-blog.csdnimg.cn/ee18edd08511453ab9a63bbcdf49ae60.png)
【手机】三星手机刷机解决SecSetupWizard已停止
三星手机恢复出厂设置之后,出现SecSetupWizard已停止的解决方案 零、问题 我手上有一部同学给的三星 GT-S6812I,这几天搞了张新卡,多余出的卡就放到这个手机上玩去了。因为是获取了root权限的(直接使用KingRoot就可以࿰…...
![](https://www.ngui.cc/images/no-images.jpg)
GDAL C++ API 学习之路 OGRGeometry 抽象曲线基类 OGRCurve
OGRCurve class "ogrsf_frmts.h" OGRCurve 是 OGR(OpenGIS Simple Features Reference Implementation)几何库中的一个基类,表示曲线几何对象。它是 OGRLineString 和 OGRCircularString 的抽象基类,用于表示曲…...
![](https://www.ngui.cc/images/no-images.jpg)
etcd底层支持的数据库有哪些
etcd底层的数据库可以更换。在当前版本的etcd中,它使用的是BoltDB作为默认的后端存储引擎。但是,etcd提供了接口允许您更换数据库后端,以便根据需要选择更合适的存储引擎。 以下是etcd支持的一些后端数据库选项: BoltDBÿ…...
![](https://img-blog.csdnimg.cn/335b54c9ef994df4a9f7ebfe7def72b5.jpg)
linux设备驱动的poll与fasync
什么是fasync 在 Linux 驱动程序中,fasync 是一种机制,用于在异步事件发生时通知进程。它允许进程在等待设备事件时,不必像传统的轮询方式那样持续地查询设备状态。 具体来说,当进程调用 fcntl(fd, F_SETFL, O_ASYNC) 函数时&am…...
![](https://img-blog.csdnimg.cn/f7ef1ce1ba4d44b5963d29b3ea5e24a3.png)
TortoiseGit安装与配置
注:在安装TortoiseGit之前我已经安装了git工具。 二、Git的诞生及环境配置_tortoisegit安装包_朱嘉鼎的博客-CSDN博客 1、TortoiseGit简介 TortoiseGit是基于TortoiseSVN的Git版本的Windows Shell界面。它是开源的,可以完全免费使用。 TortoiseGit 支持…...
![](https://www.ngui.cc/images/no-images.jpg)
Java代码打印空心菱形(小练习)
回看基础 利用Java代码打印一个空心菱形 //5. 打印空心菱形 import java.util.Scanner; public class MulForExercise01 {//编写一个 main 方法public static void main(String[] args) {Scanner myScanner new Scanner(System.in);System.out.println("请输入正三角的行…...
![](https://img-blog.csdnimg.cn/e81aab1dfdb440babea7bc4b0c7a6d64.png)
【性能优化】MySQL百万数据深度分页优化思路分析
业务场景 一般在项目开发中会有很多的统计数据需要进行上报分析,一般在分析过后会在后台展示出来给运营和产品进行分页查看,最常见的一种就是根据日期进行筛选。这种统计数据随着时间的推移数据量会慢慢的变大,达到百万、千万条数据只是时间问…...
交叉编译工具链的安装、配置、使用
一、交叉编译的概念 交叉编译是在一个平台上生成另一个平台上的可执行代码。 编译:一个平台上生成在该平台上的可执行文件。 例如:我们的Windows上面编写的C51代码,并编译成可执行的代码,如xx.hex.在C51上面运行。 我们在Ubunt…...
![](https://img-blog.csdnimg.cn/26f7a1e0803441dc8fd97b6fabc4d79d.png)
【C++ 进阶】继承
一.继承的定义格式 基类又叫父类,派生类又叫子类; 二.继承方式 继承方式分为三种: 1.public继承 2.protected继承 3.private继承 基类成员与继承方式的关系共有9种,见下表: 虽然说是有9种,但其实最常用的还…...
![](https://img-blog.csdnimg.cn/20e79ad17cc244569eafef3087871bea.png)
Git使用详细教程
1. cmd面板的常用命令 clear:清屏cd 文件夹名称----进入文件夹cd … 进入上一级目录(两个点)dir 查看当前目录下的文件和文件夹(全拼:directory)Is 查看当前目录下的文件和文件夹touch 文件名----创建文件echo 内容 > 创建文件名----创建文件并写入内容rm 文件名…...
![](https://www.ngui.cc/images/no-images.jpg)
小程序 表单验证
使用 WxValidate.js 插件来校验表单数据 常用实例方法 名称返回类型描述checkForm(e)boolean验证所有字段的规则,返回验证是否通过。valid()boolean返回验证是否通过。size()number返回错误信息的个数。validationErrors()array返回所有错误信息。addMethod(name…...
![](https://img-blog.csdnimg.cn/b494a08c77524403b7d22ccf5cf9e392.png)
本地仓库推送至远程仓库
1. 本地生成ssh密钥对 ssh-keygen -t rsa -C 邮箱2. 添加公钥到gitlab/github/gitee上 打开C:\Users\用户名\.ssh目录下生成的密钥文件id_rsa.pub,把内容复制到如下文本框中 删除Expiration date显示的日期,公钥有效期变成永久,之后点Add K…...
![](https://img-blog.csdnimg.cn/640430fb69724608a6c07ed18dc2e75f.png)
【Unity2D】角色动画的切换
动画状态转换 第一种方法是设置一个中间状态,从中间状态向其余各种状态切换,且各状态向其他状态需要设置参数 实现动作转移时右键点击Make Transition即可 实现动画转移需要设置条件 点击一种动画到另一种动画的线 ,然后点击加号添加Condi…...
![](https://img-blog.csdnimg.cn/c49e56b3c10e453ba8dbd43912d6e3c8.png)
【MATLAB第62期】基于MATLAB的PSO-NN、BBO-NN、前馈神经网络NN回归预测对比
【MATLAB第62期】基于MATLAB的PSO-NN、BBO-NN、前馈神经网络NN回归预测对比 一、数据设置 1、7输入1输出 2、103行样本 3、80个训练样本,23个测试样本 二、效果展示 NN训练集数据的R2为:0.73013 NN测试集数据的R2为:0.23848 NN训练集数据的…...
![](https://img-blog.csdnimg.cn/img_convert/6dca08492ac8ea418959ccbf0aefed3c.png)
深度剖析C++ 异常机制
传统排错 我们早在 C 程序里面传统的错误处理手段有: 终止程序,如 assert;缺陷是用户难以接受,说白了就是一种及其粗暴的手法,比如发生内存错误,除0错误时就会终止程序。 返回错误码。缺陷是需要我们自己…...
![](https://images2018.cnblogs.com/blog/1296594/201804/1296594-20180415220335051-1595643966.jpg)
组服务器做网站/seo排名公司
一、码云链接 项目名称FAO 码云链接 二、需求分析 实现一个命令行程序;自动生成小学四则运算题目(加、减、乘、除)支持整数支持多运算符(比如生成包含100个运算符的题目)支持真分数统计正确率三、设计思路 首先设计一个基础的数据类ÿ…...
![](/images/no-images.jpg)
wordpress设置背景/合肥做网站哪家好
忙,还有两周多就要上线了,可是项目也就开始两周多。我现在估计已经快疯了。忙的时候,觉得自己实在是有心无力。如果说blog是一块镜子,那么我希望逃避。夜深人静的时候,我都不逃避,但是我已经累的倒下了&…...
![](https://img-blog.csdnimg.cn/img_convert/df37243a21c1b006fd27baf6e786bd69.png)
年前做招聘网站话术/人脉推广app
Git 教程 推荐电商源码 Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。 Git 与常用的版本控制工具 CVS, Subversion 等不同,它…...
个人如何建网站/自媒体是如何赚钱的
//logger.h/*//类名:CLogger//功能介绍:Win平台日志记录功能,多线程安全,支持写日志级别的设置,日志格式包含日志等级,日志时间,文件名,行号信息//作者:sunflover 2016-1…...
![](https://img-blog.csdnimg.cn/img_convert/2e3e9c1b8cf954ce8f499924207cf2b9.png)
北京网站开发设计/郑州seo外包费用
mysql的常用命令一. 登录数据库1. 登录本地数据库:mysql–u 用户名 –p;一般情况下都为:mysql -u root -p;在DOS下你输入以上命令之后,就会让你输入密码,输入正确的密码之后,就可以成功登录mysql数据库二&a…...
可以做超链接或锚文本的网站有哪些/怎么联系百度客服
对于cJSON的使用,我主要是用来模拟远程服务器端返回的一个json类型的目录结构,客户端进行获取并进行解析,把解析出来的目录按照原本的结构显示在本地。 cJSON是一个超轻巧,携带方便,单文件,简单的可以作为…...