关于vector迭代器失效的几种情况总结

发布时间 - 2026-01-10 22:01:03    点击率:

在泛型编程还是STL的实际运用中,迭代器(iterator)无疑扮演者重要的角色。迭代器是一种类似于指针的对象(如可以内容提领,成员访问等),但他又不仅仅是一种普通的指针。

关于迭代器失效,我们可以看下面这个例子:

#include<vector>
#include<list>
void PrintVector(const vector<int>& v)
{
  vector<int>::const_iterator it = v.begin();
  while (it!=v.end())
  {
    cout << *it << " ";
    it++;
  }
  cout << endl;
}
void TestIterator()
{
    //迭代器失效
vector<int> v;
v.push_back(1);
v.push_back(2);
v.push_back(2);
v.push_back(4);
v.push_back(2);
v.push_back(3);
v.push_back(4);
v.push_back(5);
v.push_back(4);
v.push_back(4);
v.push_back(6);
  vector<int>::iterator it = v.begin();
  while (it != v.end())
  {
    if (*it % 2 == 0)
    {
      it = v.erase(it);
      ++it;
    }
    
  }
  PrintVector(v);
}
void main()
{
  TestIterator();
}

这样的代码乍一看好像没有什么问题,但是他是有问题的,因为在vector是顺序存储的,在vector中删除一个元素之后,我们需要为vector重新分配一个空间,存放在旧的空间的元素被复制到新的空间,如果删除的这个元素的迭代器会指向下一个元素之后还++it,则在复制的时候找不到下一个元素,因此会使删除点及删除点之后的迭代器失效。

正确做法是:

vector<int>::iterator it = v.begin();
  while (it != v.end())
  {
    if (*it % 2 == 0)
    {
      it = v.erase(it);
    }
    else
    {
      ++it;
    }
    
  }
  PrintVector(v);

对于添加元素也是同理,如果当前容器中有10个元素,现在又要添加元素到容器中,如果内存中没有多余的空间,因此vector需要重新开辟空间来存储原来的元素以及新添加的元素。在新的空间复制原理来的元素,并插入新的元素,最后撤销原来的空间,这种情况发生会使所有迭代器都失效。

总结:vector迭代器的几种失效的情况:

1、当插入(push_back)一个元素后,end操作返回的迭代器肯定失效。

2、当插入(push_back)一个元素后,capacity返回值与没有插入元素之前相比有改变,则需要重新加载整个容器,此时first和end操 作返回的迭代器都会失效。

3、当进行删除操作(erase,pop_back)后,指向删除点的迭代器全部失效;指向删除点后面的元素的迭代器也将全部失效。

以上就是小编为大家带来的关于vector迭代器失效的几种情况总结全部内容了,希望大家多多支持~


# vector  # 迭代器失效  # C++中vector迭代器失效问题详解  # c++迭代器失效的情况汇总  # vector list map 遍历删除制定元素 防止迭代器失效的实例  # 浅谈c++ stl迭代器失效的问题  # C/C++迭代器的失效问题详解  # 迭代  # 是一种  # 几种  # 会使  # 提领  # 放在  # 是有  # 找不到  # 中有  # 但他  # 我们可以  # 也将  # 又要  # 这种情况  # 又不  # 则在  # 类似于  # 什么问题  # 小编  # 到新 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  iOS正则表达式验证手机号、邮箱、身份证号等  使用豆包 AI 辅助进行简单网页 HTML 结构设计  Android实现代码画虚线边框背景效果  Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  如何快速搭建支持数据库操作的智能建站平台?  打开php文件提示内存不足_怎么调整php内存限制【解决方案】  如何快速上传建站程序避免常见错误?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  微信小程序 canvas开发实例及注意事项  如何续费美橙建站之星域名及服务?  Laravel怎么实现支付功能_Laravel集成支付宝微信支付  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  三星、SK海力士获美批准:可向中国出口芯片制造设备  PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)  Laravel中的withCount方法怎么高效统计关联模型数量  成都网站制作公司哪家好,四川省职工服务网是做什么用?  Laravel如何实现API资源集合?(Resource Collection教程)  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  Linux系统运维自动化项目教程_Ansible批量管理实战  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  深圳网站制作的公司有哪些,dido官方网站?  如何快速打造个性化非模板自助建站?  大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?  Laravel如何配置Horizon来管理队列?(安装和使用)  Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲  如何在建站之星绑定自定义域名?  Python进程池调度策略_任务分发说明【指导】  魔方云NAT建站如何实现端口转发?  如何在IIS中新建站点并配置端口与物理路径?  如何用JavaScript实现文本编辑器_光标和选区怎么处理  ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  如何用已有域名快速搭建网站?  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  如何在万网自助建站中设置域名及备案?  百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏  如何在VPS电脑上快速搭建网站?  如何在橙子建站上传落地页?操作指南详解  网站制作免费,什么网站能看正片电影?  如何在云主机快速搭建网站站点?  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】  iOS发送验证码倒计时应用  如何解决hover在ie6中的兼容性问题  iOS UIView常见属性方法小结  Laravel API资源类怎么用_Laravel API Resource数据转换